html {
  font-family: '游ゴシック体', YuGothic, '游ゴシック', 'Yu Gothic', 'Hiragino Kaku Gothic ProN', Meiryo, Arial, sans-serif;
  font-size: 62.5%;
  font-weight: 400;
  line-height: 1.2;
  overflow-y: scroll;
  padding: constant(safe-area-inset-top) constant(safe-area-inset-right) constant(safe-area-inset-bottom) constant(safe-area-inset-left);
  padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
  letter-spacing: .06em;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale
}
*, :after, :before {
  box-sizing: border-box
}
a {
  text-decoration: none;
  color: #000
}
a.is-disable {
  color: rgba(125, 125, 125, .4) !important
}
a.is-disable:hover {
  cursor: default
}
a.link--blank {
  position: relative;
  padding: 0 2rem 0 0;
  text-decoration: underline
}
a.link--blank:after {
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%)
}
a.link--blank:hover {
  text-decoration: none
}
.link--back {
  margin: 4rem 0 0;
  text-align: center
}
.link--back a {
  font-size: 1.6rem;
  text-decoration: underline
}
.link--back a:hover {
  text-decoration: none
}
.link--blank {
  position: relative
}
.link--blank:after {
  position: absolute;
  top: .8rem;
  right: .8rem;
  width: 1.3rem;
  height: 1.3rem;
  content: '';
  background: url(https://www.ittokai.or.jp/iryounavi/wp-content/uploads/it-cache/fonts/2e8f5acc4f079eb8e60491e892c0450b.svg) no-repeat;
  background-size: 100% auto
}
.break {
  display: inline-block
}
body.is-loaded .c-overlay {
  background: 0 0
}
.c-overlay {
  position: fixed;
  z-index: 50;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  -webkit-transition: background .3s;
  transition: background .3s;
  background: #f3f6ef
}
.c-overlay.is-invert {
  background: rgba(0, 0, 0, .5)
}
.is-stay .icon--face:nth-child(1) img, .is-stay .icon--face:nth-child(10) img, .is-stay .icon--face:nth-child(11) img, .is-stay .icon--face:nth-child(4) img, .is-stay .icon--face:nth-child(6) img, .is-stay .icon--face:nth-child(9) img {
  -webkit-animation: fuwafuwa 3s infinite ease alternate;
  animation: fuwafuwa 3s infinite ease alternate
}
.is-stay .icon--face:nth-child(12) img, .is-stay .icon--face:nth-child(2) img, .is-stay .icon--face:nth-child(3) img, .is-stay .icon--face:nth-child(5) img, .is-stay .icon--face:nth-child(7) img, .is-stay .icon--face:nth-child(8) img {
  -webkit-animation: fuwafuwa 6s infinite ease alternate;
  animation: fuwafuwa 6s infinite ease alternate
}
a, abbr, acronym, address, applet, article, aside, audio, b, big, blockquote, body, canvas, center, cite, code, dd, del, dfn, div, dl, dt, em, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav, object, ol, output, p, pre, q, ruby, s, samp, section, small, span, strike, strong, sub, summary, sup, table, td, th, time, tr, tt, u, ul, var, video {
  margin: 0;
  padding: 0;
  vertical-align: baseline;
  border: 0
}
ol, ul {
  list-style: none
}
html {
  box-sizing: border-box;
  cursor: default;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%
}
article, aside, footer, header, nav, section {
  display: block
}
body {
  margin: 0
}
figcaption, figure, main {
  display: block
}
hr {
  overflow: visible;
  box-sizing: content-box;
  height: 0
}
nav ol, nav ul {
  list-style: none
}
pre {
  font-family: monospace, monospace;
  font-size: 1em
}
abbr[title] {
  text-decoration: underline;
  text-decoration: underline dotted;
  border-bottom: none;
  -webkit-text-decoration: underline dotted
}
b, strong {
  font-weight: inherit
}
b, strong {
  font-weight: bolder
}
code, kbd, samp {
  font-family: monospace, monospace;
  font-size: 1em
}
dfn {
  font-style: italic
}
mark {
  color: #000;
  background-color: #ff0
}
small {
  font-size: 80%
}
sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline
}
sub {
  bottom: -.25em
}
sup {
  top: -.5em
}
:-moz-selection {
  color: #000;
  background-color: #b3d4fc;
  text-shadow: none
}
:selection {
  color: #000;
  background-color: #b3d4fc;
  text-shadow: none
}
audio, canvas, iframe, img, svg, video {
  vertical-align: middle
}
audio, video {
  display: inline-block
}
audio:not([controls]) {
  display: none;
  height: 0
}
img {
  max-width: 100%;
  height: auto;
  border-style: none
}
svg {
  fill: currentColor
}
svg:not(:root) {
  overflow: hidden
}
table {
  width: 100%;
  border-spacing: 0;
  border-collapse: collapse
}
button, input, optgroup, select, textarea {
  margin: 0
}
button, input, select, textarea {
  font-size: inherit;
  line-height: inherit;
  color: inherit;
  background-color: transparent
}
button, input {
  overflow: visible
}
button, select {
  text-transform: none
}
[type=reset], [type=submit], button, html [type=button] {
  -webkit-appearance: button;
  -moz-appearance: button;
  appearance: button
}
[type=button]:-moz-focus-inner, [type=reset]:-moz-focus-inner, [type=submit]:-moz-focus-inner, button:-moz-focus-inner {
  padding: 0;
  border-style: none
}
[type=button]:-moz-focusring, [type=reset]:-moz-focusring, [type=submit]:-moz-focusring, button:-moz-focusring {
  outline: 1px dotted ButtonText
}
legend {
  display: table;
  box-sizing: border-box;
  max-width: 100%;
  padding: 0;
  white-space: normal;
  color: inherit
}
progress {
  display: inline-block;
  vertical-align: baseline
}
textarea {
  overflow: auto;
  resize: vertical
}
[type=checkbox], [type=radio] {
  box-sizing: border-box;
  padding: 0
}
[type=number]:-webkit-inner-spin-button, [type=number]:-webkit-outer-spin-button {
  height: auto
}
[type=search] {
  outline-offset: -2px;
  -webkit-appearance: textfield;
  -moz-appearance: textfield;
  appearance: textfield
}
[type=search]:-webkit-search-cancel-button, [type=search]:-webkit-search-decoration {
  -webkit-appearance: none;
  appearance: none
}
:-webkit-file-upload-button {
  font: inherit;
  -webkit-appearance: button;
  appearance: button
}
details, menu {
  display: block
}
summary {
  display: list-item
}
canvas {
  display: inline-block
}
template {
  display: none
}
[tabindex], a, area, button, input, label, select, summary, textarea {
  touch-action: manipulation
}
[hidden] {
  display: none
}
[aria-busy=true] {
  cursor: progress
}
[aria-controls] {
  cursor: pointer
}
[aria-hidden=false][hidden]:not(:focus) {
  position: absolute;
  display: inherit;
  clip: rect(0, 0, 0, 0)
}
[aria-disabled] {
  cursor: default
}
h1, h2, h3, h4, h5 {
  font-weight: 400
}
.gsc-control-cse {
  padding: 0 !important;
  border: none !important;
  background: 0 0 !important
}
.gsc-search-box {
  margin: 0 !important
}
.gsc-search-box .gsc-input {
  padding: 0 !important
}
.gsc-input-box {
  border: none !important;
  background: 0 0 !important
}
.gsib_a {
  padding: 0 !important
}
.gsib_b {
  display: none !important
}
.gsc-search-button {
  display: none !important
}
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  -khtml-user-select: none;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent
}
.slick-list {
  position: relative;
  display: block;
  overflow: hidden;
  margin: 0;
  padding: 0
}
.slick-list:focus {
  outline: 0
}
.slick-list.dragging {
  cursor: pointer;
  cursor: hand
}
.slick-slider .slick-list, .slick-slider .slick-track {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0)
}
.slick-track {
  position: relative;
  top: 0;
  left: 0;
  display: block;
  margin-right: auto;
  margin-left: auto
}
.slick-track:after, .slick-track:before {
  display: table;
  content: ''
}
.slick-track:after {
  clear: both
}
.slick-loading .slick-track {
  visibility: hidden
}
.slick-slide {
  display: none;
  float: left;
  height: 100%;
  min-height: 1px
}
[dir=rtl] .slick-slide {
  float: right
}
.slick-slide img {
  display: block
}
.slick-slide.slick-loading img {
  display: none
}
.slick-slide.dragging img {
  pointer-events: none
}
.slick-initialized .slick-slide {
  display: block
}
.slick-loading .slick-slide {
  visibility: hidden
}
.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent
}
.slick-arrow.slick-hidden {
  display: none
}
.slick-dotted.slick-slider {
  padding-bottom: 30px
}
.slick-dots {
  position: absolute;
  bottom: 0;
  display: block;
  width: 100%;
  margin: 0;
  padding: 0;
  list-style: none;
  text-align: center
}
.slick-dots li {
  position: relative;
  display: inline-block;
  width: 11px;
  height: 11px;
  margin: 0 2.5px;
  padding: 0;
  cursor: pointer
}
.slick-dots li button {
  font-size: 0;
  line-height: 0;
  display: block;
  width: 11px;
  height: 11px;
  padding: 5px;
  cursor: pointer;
  color: transparent;
  border: 0;
  outline: 0;
  background: 0 0
}
.slick-dots li button:focus, .slick-dots li button:hover {
  outline: 0
}
.slick-dots li button:focus:before, .slick-dots li button:hover:before {
  background: #96cc16
}
.slick-dots li button:before {
  position: absolute;
  top: 0;
  left: 0;
  width: 11px;
  height: 11px;
  content: '';
  border-radius: 50%;
  background: #d9d9d9
}
.slick-dots li.slick-active button:before {
  background: #96cc16
}
.l-content {
  width: 100%;
  max-width: 100rem;
  margin-right: auto;
  margin-left: auto
}
.l-content--curves {
  position: relative;
  padding-top: 2rem
}
.l-content--curves:before {
  position: absolute;
  z-index: 1;
  top: .1rem;
  left: 50%;
  width: calc(100% - 4rem);
  height: 4rem;
  content: '';
  -webkit-transform: translate(-50%, -100%);
  transform: translate(-50%, -100%);
  border-radius: 3rem 3rem 0 0;
  background: #fff
}
.l-content--newslist {
  padding-bottom: 6rem
}
.l-content--newsarticle {
  padding: 6rem 0 5rem 0
}
.l-footer aside {
  width: 100%;
  margin: 0 auto
}
.l-section--primary {
  background: #f3f6ef
}
.l-section--o, .l-section--w {
  width: 100%;
  max-width: 100rem;
  margin-right: auto;
  margin-left: auto;
  border-radius: 6rem
}
.l-section--t {
  width: 100%;
  max-width: 100rem;
  margin-right: auto;
  margin-left: auto
}
.l-section--w {
  background: #fff
}
.l-section--o {
  background: #f39800
}
.l-page--about .section-title--page, .l-page--service .section-title--page {
  margin-top: 3.5rem
}
.l-page--about .section-lead, .l-page--about .section-textarea, .l-page--service .section-lead, .l-page--service .section-textarea {
  margin-top: 3.5rem
}
.l-page--about .section-lead, .l-page--service .section-lead {
  margin: 3.5rem auto 6em auto
}
.btn--comingsoon {
  position: relative
}
.btn--comingsoon:after {
  font-size: 1.6rem;
  position: absolute;
  z-index: 2;
  top: 50%;
  right: 0;
  left: 0;
  margin: auto;
  content: 'Coming soon';
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  text-align: center;
  color: #7d7d7d
}
.btn--comingsoon:before {
  position: absolute;
  z-index: 1;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: '';
  text-align: center;
  opacity: .8;
  border-radius: 200px;
  background-color: #fff
}
.l-footer {
  position: relative;
  z-index: 1;
  overflow: hidden;
  padding: 6rem 0 2rem;
  background: #f3f6ef
}
.l-footer .footer__inner {
  position: relative;
  z-index: 2
}
.l-footer .footer__bg {
  position: absolute;
  z-index: 1;
  left: 0;
  width: 100%
}
.l-footer aside {
  max-width: 82.4rem;
  padding: 5rem 3rem;
  border-radius: 6rem;
  background: #fff;
  box-shadow: 0 0 5px rgba(0, 0, 0, .15)
}
.l-footer .section-title--secondary span:nth-child(1) {
  color: #f39800
}
.l-footer .section-title--secondary span:nth-child(2):after {
  background: #f39800
}
.l-footer .aside__row {
  position: relative;
  display: -webkit-box;
  display: flex;
  margin-top: 4rem;
  -webkit-box-pack: justify;
  justify-content: space-between
}
.l-footer .aside__row:before {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: .1rem;
  content: '';
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background: #d0d0d0
}
.l-footer .aside__row section {
  text-align: center
}
.l-footer .aside__row section > * + * {
  margin-top: 2rem
}
.l-footer .aside__row h3, .l-footer .aside__row p {
  font-size: 1.5rem
}
.l-footer .tel {
  width: 100%;
  max-width: 30.1rem
}
.l-footer .menu {
  display: -webkit-box;
  display: flex;
  margin-top: 23rem;
  -webkit-box-pack: center;
  justify-content: center
}
.l-footer .menu li {
  padding: 0 10px;
  border-right: 1px solid #7d7d7d
}
.l-footer .menu li:last-child {
  border-right: none
}
.l-footer .menu a {
  text-decoration: underline;
  color: #7d7d7d
}
.l-footer .copyright {
  font-size: 1.2rem;
  margin-top: 2rem;
  text-align: center;
  color: #7d7d7d
}
.l-header-recruit {
  position: absolute;
  z-index: 40;
  top: 0;
  left: 0;
  width: 100%;
  padding: 2rem
}
.l-header-recruit .header__front {
  display: -webkit-box;
  display: flex;
  visibility: visible;
  -webkit-transition: .3s;
  transition: .3s;
  opacity: 1;
  -webkit-box-align: end;
  align-items: flex-end
}
.l-header-recruit .header__front.is-hide {
  visibility: hidden;
  opacity: 0
}
.l-header-recruit .header__logo {
  width: 100%;
  max-width: 8.8rem
}
.l-header-recruit .header__desc {
  display: -webkit-box;
  display: flex;
  margin: 0 0 0 1rem;
  -webkit-box-align: center;
  align-items: center
}
.l-header-recruit .header__desc i {
  width: .5rem
}
.l-header-recruit .header__desc span {
  font-family: Roboto, sans-serif;
  font-size: .8rem;
  font-weight: 700;
  padding: 0 .5rem;
  color: #fff
}
.l-header-recruit .header__entry {
  display: none
}
.l-header-recruit .header__entry p {
  font-family: Roboto, sans-serif;
  font-size: 2rem;
  font-weight: 700;
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: flex;
  height: 4.8rem;
  color: #fff;
  border-radius: 24px;
  background: #f39800;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  justify-content: center
}
.l-header-recruit .header__entry i {
  position: absolute;
  top: 0;
  right: 1.8rem;
  bottom: 0;
  width: 1.8rem;
  height: 1.8rem;
  margin: auto;
  border-radius: 50%;
  background: #fff
}
.l-header-recruit .header__entry i:before {
  position: absolute;
  top: 50%;
  left: 50%;
  width: .5rem;
  height: .5rem;
  content: '';
  -webkit-transform: translate(-50%, -50%) rotate(-135deg);
  transform: translate(-50%, -50%) rotate(-135deg);
  border-bottom: 1.5px solid #f39800;
  border-left: 1.5px solid #f39800
}
.l-header-recruit .header__entry ul {
  position: absolute;
  top: 2.4rem;
  left: 0;
  visibility: hidden;
  width: 100%;
  padding: 3.4rem 0 1rem;
  -webkit-transition: .3s;
  transition: .3s;
  -webkit-transform: translateY(-1rem);
  transform: translateY(-1rem);
  opacity: 0;
  border-radius: 0 0 24px 24px;
  background: #fff
}
.l-header-recruit .header__entry ul.is-show {
  visibility: visible;
  -webkit-transform: translateY(0);
  transform: translateY(0);
  opacity: 1
}
.l-header-recruit .header__entry a {
  font-size: 1.4rem;
  font-weight: 700;
  display: block;
  padding: .5rem;
  text-align: center;
  color: #f39800
}
.l-header-recruit .header__nav {
  position: fixed;
  z-index: 40;
  top: 0;
  left: 0;
  visibility: hidden;
  overflow-y: scroll;
  width: 100%;
  height: 100vh;
  -webkit-transition: .5s .5s ease-in-out;
  transition: .5s .5s ease-in-out;
  -webkit-transform: translateX(100%);
  transform: translateX(100%);
  background: #f39800;
  -webkit-overflow-scrolling: touch
}
.l-header-recruit .header__nav .header__nav__container {
  display: table;
  width: 100%;
  height: 100%;
  -webkit-transition: .5s ease-in-out;
  transition: .5s ease-in-out;
  -webkit-transform: translateX(3rem);
  transform: translateX(3rem);
  opacity: 0
}
.l-header-recruit .header__nav .header__nav__body {
  display: table-cell;
  padding: 8rem 2rem;
  vertical-align: middle
}
.l-header-recruit .header__nav .header__nav__inner div:nth-child(1) {
  margin: 0 0 2rem
}
.l-header-recruit .header__nav .header__nav__inner div:nth-child(1) li {
  margin: 0 0 2rem;
  text-align: center
}
.l-header-recruit .header__nav .header__nav__inner div:nth-child(1) li:last-child {
  margin: 0
}
.l-header-recruit .header__nav .header__nav__inner div:nth-child(1) a {
  font-size: 2rem;
  font-weight: 700;
  color: #fff
}
.l-header-recruit .header__nav .header__nav__inner div:nth-child(2) {
  padding: 3rem;
  border-radius: 20px;
  background: #fff
}
.l-header-recruit .header__nav .header__nav__inner div:nth-child(2) p {
  font-family: Roboto, sans-serif;
  font-size: 1.8rem;
  font-weight: 700;
  margin: 0 0 2rem;
  text-align: center;
  color: #f39800
}
.l-header-recruit .header__nav .header__nav__inner div:nth-child(2) li {
  margin: 0 0 2rem;
  text-align: center
}
.l-header-recruit .header__nav .header__nav__inner div:nth-child(2) li:last-child {
  margin: 0
}
.l-header-recruit .header__nav .header__nav__inner div:nth-child(2) a {
  font-size: 2rem;
  font-weight: 700;
  color: #f39800
}
.l-header-recruit .header__opener, .l-header-recruit .header__opener span {
  display: inline-block
}
.l-header-recruit .header__opener {
  position: fixed;
  z-index: 40;
  top: .5rem;
  right: 1.5rem;
  width: 6.1rem;
  height: 5.4rem;
  background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/icon-beans01.png) no-repeat;
  background-size: 100% auto
}
.l-header-recruit .header__opener span {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 2rem;
  height: .2rem;
  -webkit-transition: .2s;
  transition: .2s;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  background: #fff
}
.l-header-recruit .header__opener span:nth-of-type(1) {
  margin: -.6rem 0 0
}
.l-header-recruit .header__opener span:nth-of-type(3) {
  margin: .6rem 0 0
}
.l-header-recruit--under .header__desc span {
  color: #7d7d7d
}
.l-header-recruit.is-active .header__nav {
  visibility: visible;
  -webkit-transition: .5s ease-in-out;
  transition: .5s ease-in-out;
  -webkit-transform: translateX(0);
  transform: translateX(0)
}
.l-header-recruit.is-active .header__nav__container {
  -webkit-transition: .5s .5s ease-in-out;
  transition: .5s .5s ease-in-out;
  -webkit-transform: translateX(0);
  transform: translateX(0);
  opacity: 1
}
.l-header-recruit.is-active .header__opener {
  -webkit-transform: translateY(0);
  transform: translateY(0);
  background: 0 0
}
.l-header-recruit.is-active .header__opener span:nth-of-type(1) {
  margin: 0;
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
  transform: translate(-50%, -50%) rotate(45deg)
}
.l-header-recruit.is-active .header__opener span:nth-of-type(2) {
  opacity: 0
}
.l-header-recruit.is-active .header__opener span:nth-of-type(3) {
  margin: 0;
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
  transform: translate(-50%, -50%) rotate(-45deg)
}
.l-header {
  display: -webkit-box;
  display: flex;
  width: 100%;
  height: 5rem;
  padding: 0 2rem;
  -webkit-box-align: center;
  align-items: center
}
.l-header .header__logo {
  width: 100%
}
.l-header .header__nav ul {
  display: -webkit-box;
  display: flex;
  -webkit-box-pack: center;
  justify-content: center
}
.l-header .header__nav li {
  line-height: 1;
  position: relative
}
.l-header .header__nav a {
  font-size: 1.6rem;
  font-weight: 700;
  color: #7d7d7d
}
.l-header .header__nav a.is-current {
  position: relative
}
.l-header .header__nav a.is-current:after {
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 10rem;
  height: .4rem;
  content: '';
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  border-radius: .2rem;
  background: #f39800
}
.l-header .header__nav a.is-current:after {
  bottom: -1.5rem;
  width: 100%;
  height: .2rem;
  background: #d0d0d0
}
.l-header .header__drawer > a {
  position: relative
}
.l-header .header__drawer ul {
  flex-direction: column;
  box-sizing: border-box;
  padding: 2rem;
  border-radius: 25px;
  background: #f39800;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal
}
.l-header .header__drawer ul li {
  margin: 0 0 2rem;
  text-align: center
}
.l-header .header__drawer ul li:last-child {
  margin: 0
}
.l-header .header__drawer ul a {
  font-size: 1.4rem;
  color: #fff
}
.l-header .header__opener, .l-header .header__opener span {
  display: inline-block
}
.l-header .header__opener {
  position: fixed;
  z-index: 40;
  top: .5rem;
  right: 1.5rem;
  width: 5rem;
  height: 4.5rem;
  background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/icon-beans01.png) no-repeat;
  background-size: 100% auto
}
.l-header .header__opener span {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 2rem;
  height: .2rem;
  -webkit-transition: .2s;
  transition: .2s;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  background: #fff
}
.l-header .header__opener span:nth-of-type(1) {
  margin: -.6rem 0 0
}
.l-header .header__opener span:nth-of-type(3) {
  margin: .6rem 0 0
}
.l-header.is-active .header__opener {
  -webkit-transform: translateY(0);
  transform: translateY(0);
  background: 0 0
}
.l-header.is-active .header__opener span {
  background: #000
}
.l-header.is-active .header__opener span:nth-of-type(1) {
  margin: 0;
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
  transform: translate(-50%, -50%) rotate(45deg)
}
.l-header.is-active .header__opener span:nth-of-type(2) {
  opacity: 0
}
.l-header.is-active .header__opener span:nth-of-type(3) {
  margin: 0;
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
  transform: translate(-50%, -50%) rotate(-45deg)
}
.hero {
  position: relative
}
.hero .hero__title {
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.4;
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  margin-top: 2rem;
  padding: 0 2rem;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  text-align: center;
  letter-spacing: .24em;
  color: #fff
}
.hero .hero__title span {
  font-family: Roboto, sans-serif;
  font-size: 2rem;
  display: block;
  padding-bottom: 1rem;
  letter-spacing: .12em
}
.hero .hero__category {
  font-size: 1.8rem;
  font-weight: 700;
  margin: 0 2rem;
  padding-bottom: 1.5em;
  color: #7d7d7d
}
.hero .hero__text {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 2;
  margin: 0 2rem 4rem 2rem;
  text-align: left;
  color: #7d7d7d
}
.l-page--top .page__movie {
  position: fixed;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh
}
.l-page--top .page__movie video {
  position: absolute;
  z-index: -1;
  top: 0;
  left: 50%;
  width: auto;
  min-width: 100%;
  height: auto;
  min-height: 100vh;
  -webkit-transform: translate(-50%, 0);
  transform: translate(-50%, 0)
}
.l-page--top .page__movie:before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  content: '';
  -webkit-transition: .3s;
  transition: .3s;
  background: #f3f6ef
}
.l-page--top .page__movie.is-play:before {
  background: rgba(0, 0, 0, 0)
}
.l-page--top .page__movie.is-invert:before {
  background: rgba(0, 0, 0, .3)
}
.l-page--top .hero {
  position: relative
}
.l-page--top .hero canvas {
  width: calc(100% + 15rem) !important;
  height: 100% !important
}
.l-page--news .hero__title {
  font-weight: 700;
  position: relative;
  top: 0 !important;
  padding: 6rem 0 5rem 0;
  -webkit-transform: translateY(0) !important;
  transform: translateY(0) !important;
  color: #f39800
}
.l-page--news .hero__title span {
  font-size: 2rem;
  position: relative;
  display: inline-block
}
.l-page--news .hero__title span::after {
  position: absolute;
  right: 0;
  bottom: -.5rem;
  left: 0;
  width: 100%;
  height: 6px;
  margin: auto;
  content: '';
  border-radius: 4px;
  background-color: #f39800
}
.l-page--download .hero__title {
  font-weight: 700;
  position: relative;
  top: 0 !important;
  padding: 6rem 0 5rem 0;
  -webkit-transform: translateY(0) !important;
  transform: translateY(0) !important;
  color: #f39800
}
.l-page--download .hero__title span {
  font-size: 2rem;
  position: relative;
  display: inline-block
}
.l-page--download .hero__title span::after {
  position: absolute;
  right: 0;
  bottom: -.5rem;
  left: 0;
  width: 100%;
  height: 6px;
  margin: auto;
  content: '';
  border-radius: 4px;
  background-color: #f39800
}
.arrow-bullet--b, .arrow-bullet--w {
  position: relative
}
.arrow-bullet--b:after, .arrow-bullet--w:after {
  position: absolute;
  top: 50%;
  left: 50%;
  width: .5rem;
  height: .5rem;
  content: '';
  -webkit-transform: translate(-50%, -50%) rotate(-135deg);
  transform: translate(-50%, -50%) rotate(-135deg)
}
.arrow-bullet--b {
  width: 3rem;
  height: 3rem;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  border-radius: 50%;
  background: #2aacf2
}
.arrow-bullet--b:after {
  border-bottom: 1.5px solid #fff;
  border-left: 1.5px solid #fff
}
.arrow-bullet--w {
  width: 3rem;
  height: 3rem;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  border-radius: 50%;
  background: #fff
}
.arrow-bullet--w:after {
  border-bottom: 1.5px solid #2aacf2;
  border-left: 1.5px solid #2aacf2
}
.btn-list > * {
  margin-top: 1rem
}
.border-btn, .border-btn--sm, .btn--primary, .btn--recruit, .btn--secondary {
  font-weight: 700;
  position: relative;
  text-align: center;
  border-radius: 3.5rem
}
.border-btn a, .border-btn--sm a, .btn--primary a, .btn--recruit a, .btn--secondary a {
  display: block;
  padding: 1.5rem 0;
  color: #7d7d7d
}
.border-btn {
  border: 4px solid #d0d0d0
}
.border-btn a {
  font-size: 1.3rem
}
.border-btn--sm {
  border: 4px solid #d0d0d0
}
.l-footer aside .border-btn a {
  font-size: 1.8rem
}
.btn--primary {
  background: #fff
}
.btn--primary a {
  font-size: 1.5rem
}
.btn--secondary {
  background: #fff
}
.btn--secondary a {
  font-size: 1.3rem
}
.btn--recruit {
  background: #2aa8ee
}
.btn--recruit a {
  font-size: 1.6rem;
  padding: 2rem 0;
  color: #fff
}
.border-btn i, .border-btn--sm i, .btn--primary i, .btn--recruit i, .btn--secondary i, .post-list .post a i {
  position: absolute;
  top: 50%;
  right: 2rem
}
.card--image .card__title {
  font-size: 2.8rem;
  font-weight: 700;
  margin: 0 0 3rem;
  text-align: center;
  color: #7d7d7d
}
.card--image .card__textarea {
  text-align: justify;
  color: #7d7d7d
}
.card--image .card__textarea p {
  font-size: 1.4rem;
  line-height: 2
}
.card-row--image {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  justify-content: space-between
}
.card-row--image .card__btn--row .border-btn--sm {
  max-width: 28rem;
  margin-right: auto;
  margin-bottom: 2rem;
  margin-left: auto
}
.card-row--image .card__list {
  display: -webkit-box;
  display: flex;
  width: 100%;
  margin: 4rem auto 0 auto;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  justify-content: space-between;
  -webkit-box-ordinal-group: 4;
  order: 3
}
.card-row--image .card__list li {
  width: 100%;
  margin-bottom: 1.5rem;
  padding: 1rem 0;
  text-align: center;
  border: 3px solid #d2d2d2;
  border-radius: 200px
}
.card-row--image .card__list li a {
  font-size: 1.6rem;
  font-weight: 700;
  display: block;
  color: #7d7d7d
}
.card-row--image .card__textarea {
  padding-bottom: 3rem;
  text-align: justify;
  color: #7d7d7d
}
.card-row--image .card__textarea p {
  font-size: 1.4rem;
  line-height: 2
}
.card-row--image .card__textarea h3 {
  font-size: 1.8rem;
  font-weight: 700;
  margin: 0 0 3rem;
  margin: 0 0 3rem;
  text-align: center;
  color: #7d7d7d
}
.card-row--image .card__textarea h3 span {
  padding: 0 0 3rem
}
.card-row--image .card__textarea__catch {
  font-weight: 700;
  position: relative;
  margin-bottom: 1rem;
  text-align: center;
  color: #f39800
}
.card-row--image .card__textarea__catch span {
  position: relative
}
.card-row--image .card__textarea__catch span::before {
  position: absolute;
  top: 50%;
  left: -44px;
  width: 38px;
  height: 2px;
  content: '';
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background-color: #f39800
}
.card-row--image .card__textarea__catch span::after {
  position: absolute;
  top: 50%;
  right: -44px;
  width: 38px;
  height: 2px;
  content: '';
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background-color: #f39800
}
.card-row--image .border-btn--sm {
  max-width: 28rem;
  margin-right: auto;
  margin-left: auto
}
.card-row--text {
  margin: 6rem auto
}
.card-row--text .card__textarea {
  padding-bottom: 3rem;
  text-align: justify;
  color: #7d7d7d
}
.card-row--text .card__textarea p {
  font-size: 1.4rem;
  line-height: 2
}
.card-row--text .card__textarea h3 {
  font-size: 1.8rem;
  font-weight: 700;
  margin: 0 0 3rem;
  margin: 0 0 3rem;
  text-align: center;
  color: #7d7d7d
}
.card-row--text .card__textarea h3 span {
  padding: 0 0 3rem
}
.card-row--text .card__textarea__catch {
  font-weight: 700;
  position: relative;
  margin-bottom: 1rem;
  text-align: center;
  color: #f39800
}
.card-row--text .card__textarea__catch span {
  position: relative
}
.card-row--text .card__textarea__catch span::before {
  position: absolute;
  top: 50%;
  left: -44px;
  width: 38px;
  height: 2px;
  content: '';
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background-color: #f39800
}
.card-row--text .card__textarea__catch span::after {
  position: absolute;
  top: 50%;
  right: -44px;
  width: 38px;
  height: 2px;
  content: '';
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background-color: #f39800
}
.card-row--text .card__list {
  display: -webkit-box;
  display: flex;
  width: 100%;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  justify-content: space-between;
  -webkit-box-ordinal-group: 4;
  order: 3
}
.card-row--text .card__list li {
  width: 100%;
  margin-bottom: 1.5rem;
  padding: 1rem 0;
  text-align: center;
  border: 3px solid #d2d2d2;
  border-radius: 200px
}
.card-row--text .card__list li a {
  font-size: 1.6rem;
  font-weight: 700;
  display: block;
  color: #7d7d7d
}
.icon-wrap--face .icon--face {
  position: absolute;
  z-index: 1
}
.icon-wrap--face .icon--face01 {
  top: -41.67%;
  left: 2.08%;
  width: 26.5%
}
.icon-wrap--face .icon--face02 {
  top: -17%;
  left: 23.33%;
  width: 16.33%
}
.icon-wrap--face .icon--face03 {
  top: 5.83%;
  left: 5.83%;
  width: 10.25%
}
.icon-wrap--face .icon--face04 {
  z-index: 2;
  top: -38.33%;
  right: 2.5%;
  width: 22.75%
}
.icon-wrap--face .icon--face05 {
  top: -18.33%;
  right: 21.67%;
  width: 17.42%
}
.icon-wrap--face .icon--face06 {
  top: -3.33%;
  right: 39.5%;
  width: 9.5%
}
.icon-wrap--face .icon--face07 {
  top: 4.17%;
  right: 4.58%;
  width: 13.83%
}
.icon-wrap--face .icon--face08 {
  bottom: -14.17%;
  left: -3.17%;
  width: 31.25%
}
.icon-wrap--face .icon--face09 {
  bottom: -9.17%;
  left: 29.42%;
  width: 14.25%
}
.icon-wrap--face .icon--face10 {
  bottom: 44.17%;
  left: 1.83%;
  width: 15.83%
}
.icon-wrap--face .icon--face11 {
  z-index: 2;
  right: -7%;
  bottom: -11.67%;
  width: 31.42%
}
.icon-wrap--face .icon--face12 {
  right: 19.75%;
  bottom: -18.33%;
  width: 17.92%
}
.text-list--dist li {
  margin-left: 1.5em;
  list-style: disc
}
.flow-list {
  display: -webkit-box;
  display: flex;
  margin-top: 2rem;
  -webkit-box-pack: center;
  justify-content: center
}
.flow-list li {
  position: relative;
  display: -webkit-box;
  display: flex;
  flex-direction: column;
  width: 6.5rem;
  height: 6.5rem;
  border: 1px solid #d0d0d0;
  border-radius: 50%;
  background: #fff;
  -webkit-box-flex: 0;
  flex: none;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal
}
.flow-list li:nth-child(1) {
  z-index: 1
}
.flow-list li:nth-child(2) {
  z-index: 2
}
.flow-list li:nth-child(3) {
  z-index: 3
}
.flow-list li:nth-child(4) {
  z-index: 4
}
.flow-list li:nth-child(5) {
  z-index: 5
}
.flow-list li + li {
  margin-left: -1rem
}
.flow-list .flow__num {
  font-family: Roboto, sans-serif;
  font-weight: 700;
  text-align: center;
  color: #f39800
}
.flow-list .flow__num span:nth-child(1) {
  font-size: 1.1rem
}
.flow-list .flow__num span:nth-child(2) {
  font-size: 2rem;
  display: block
}
.flow-list .flow__text {
  font-size: 1.8rem;
  font-weight: 700;
  display: -webkit-box;
  display: flex;
  margin-top: 1rem;
  text-align: center;
  color: #7d7d7d;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  justify-content: center
}
.post-list {
  margin-top: 5rem
}
.post-list .post {
  border-bottom: 6px solid #fff
}
.post-list .post:first-child {
  border-top: 6px solid #fff
}
.post-list .post a {
  position: relative;
  display: -webkit-box;
  display: flex;
  padding: 2rem 4.5rem 2rem 0;
  color: #fff;
  -webkit-box-align: center;
  align-items: center
}
.post-list .post__date {
  font-size: 1.2rem;
  width: 90px
}
.post-list .post__category {
  font-size: 1.4rem;
  font-weight: 700;
  width: 160px
}
.post-list .post__title {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.6;
  width: 100%;
  padding-top: .5em
}
.logo--primary {
  display: -webkit-box;
  display: flex;
  width: 17rem;
  height: 5rem;
  background: #fff;
  -webkit-box-align: center;
  align-items: center
}
.logo--primary a {
  display: block
}
.page__parent__text {
  position: absolute;
  z-index: 30;
  top: 0;
  left: 0;
  padding: 4.9rem 0 1rem;
  -webkit-transition: -webkit-transform .3s;
  transition: -webkit-transform .3s;
  transition: transform .3s;
  transition: transform .3s, -webkit-transform .3s;
  background: #fff
}
.page__parent__text .text {
  position: relative;
  display: -webkit-box;
  display: flex;
  box-sizing: content-box;
  width: 3.5rem;
  margin: 0 0 1rem;
  padding: 3rem 0;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  justify-content: center
}
.page__parent__text .text span {
  display: block
}
.page__parent__text .text span:after, .page__parent__text .text span:before {
  position: absolute;
  left: 50%;
  width: .1rem;
  height: 2.4rem;
  content: '';
  background: #000
}
.page__parent__text .text span:before {
  top: 0;
  -webkit-transform: translate(-50%, 0);
  transform: translate(-50%, 0)
}
.page__parent__text .text span:after {
  bottom: 0;
  -webkit-transform: translate(-50%, 0);
  transform: translate(-50%, 0)
}
.page__parent__text .title {
  font-family: 'Noto Serif JP', serif;
  margin: 1rem 0 0
}
.page__parent__text .title span {
  display: -webkit-box;
  display: flex;
  min-height: 12.4rem;
  margin: 0 auto;
  padding: 2rem 1.1rem;
  -ms-writing-mode: tb-rl;
  border: .1rem solid rgba(0, 0, 0, .2);
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  justify-content: center;
  -webkit-writing-mode: vertical-rl;
  writing-mode: vertical-rl
}
.page__parent__text span {
  font-size: 1.2rem;
  font-weight: 700;
  width: 1em
}
.text--section {
  font-size: 1.5rem;
  line-height: 2
}
.text--lead {
  font-size: 1.6rem;
  line-height: 2
}
.text--caption {
  font-size: 1.3rem;
  line-height: 1.75;
  color: $COLOR_TEXT01
}
.status--type01 {
  color: $COLOR_STATUS01
}
.status--type02 {
  color: $COLOR_STATUS02
}
.status--type03 {
  color: $COLOR_STATUS03
}
.section-sub-title, .section-title, .section-title--page, .section-title--secondary, .section-title--thirdry {
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
  letter-spacing: .12em;
  color: #7d7d7d
}
.section-title span:nth-child(1), .section-title--thirdry span:not(.break):nth-child(1) {
  font-family: Roboto, sans-serif;
  font-size: 2.4rem;
  font-weight: 700;
  display: block;
  text-align: center;
  color: #f39800
}
.section-title span:nth-child(2) {
  line-height: 1.4;
  position: relative;
  display: inline-block;
  padding: 0 0 1.7rem
}
.section-title span:nth-child(2):after {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1.2rem;
  content: '';
  border-radius: .6rem;
  background: #f39800
}
.section-title--secondary {
  font-size: 3rem
}
.section-title--thirdry span:not(.break):nth-child(2) {
  line-height: 1.4;
  position: relative;
  display: inline-block;
  padding: 0 0 2rem
}
.section-title--thirdry span:not(.break):nth-child(2):after {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1.2rem;
  content: '';
  border-radius: .6rem;
  background: #f39800
}
.section-title--page {
  font-size: 2.4rem;
  line-height: 1.4
}
.section-sub-title {
  font-size: 2.4rem;
  line-height: 1.5;
  margin-top: 4rem;
  color: #fff
}
.section-description {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 2;
  margin-top: 3.5rem;
  color: #7d7d7d
}
.section-title__label {
  font-size: 1.8rem;
  font-weight: 700;
  position: relative;
  text-align: center;
  letter-spacing: .12em;
  color: #7d7d7d
}
.section-title__label span {
  position: relative;
  display: inline-block;
  padding: 0 0 2.5rem
}
.section-title__label span:after {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1.2rem;
  content: '';
  border-radius: .6rem;
  background: #f39800
}
.section-title__label span:after {
  height: .8rem
}
.section-title__label--es {
  margin: 1em 0 3em
}
.section-title__label--secondary {
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
  color: #f39800
}
.section-title__label--secondary span {
  font-family: Roboto, sans-serif;
  font-size: 2.6rem;
  display: block;
  letter-spacing: .12em
}
.section-title__subtitle {
  font-size: 1.8rem;
  font-weight: 700;
  position: relative;
  margin: 1em 0 3em;
  text-align: center;
  letter-spacing: .12em;
  color: #7d7d7d
}
.section-textarea {
  text-align: justify;
  color: #7d7d7d
}
.section-textarea p {
  font-size: 1.4rem;
  line-height: 2
}
.section-textarea p + p {
  margin-top: 3rem
}
.section-lead {
  text-align: justify;
  color: #7d7d7d
}
.section-lead p {
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 2.25
}
.section-lead p + p {
  margin: 3rem 0
}
.l-page--about .section-textarea {
  position: relative
}
.l-page--about .section-textarea p {
  font-weight: 700
}
.l-page--about .section--philosophy section {
  padding: 4em 0;
  border-bottom: 2px solid #cfcfcf
}
.l-page--about .section--philosophy section:first-of-type {
  border-top: 2px solid #cfcfcf
}
.l-page--about .section-colomn {
  margin-top: 2em
}
.l-page--about .section-colomn .section-colomn__item {
  margin-top: 4em
}
.l-page--about .section-colomn .section-colomn__item p {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
  color: #7d7d7d
}
.l-page--about .section-colomn .section-colomn__item p span {
  font-size: 1.4rem;
  line-height: 2;
  display: block;
  margin-top: 1em
}
.l-page--about .section-colomn .section-colomn__item p .section-colomn__item__nomargin {
  line-height: 2.3;
  margin-top: 0
}
.l-page--about .section--movie {
  max-width: 82.4rem;
  margin-top: 6rem
}
.l-page--about .section--movie .movie__title {
  font-size: 1.8rem;
  font-weight: 700;
  margin-bottom: 2rem;
  text-align: center;
  color: #f39800
}
.l-page--about .section--movie .movie__player {
  position: relative
}
.l-page--about .section--movie .movie__player > p {
  font-size: 1.4rem;
  font-weight: 700;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-top: 5rem;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  color: #fff
}
.l-page--about .section--movie .movie + .movie {
  margin-top: 4rem
}
.l-page--about .section--movie video {
  width: 100%
}
.l-page--about .section-wrap {
  display: -webkit-box;
  display: flex;
  max-width: 100rem;
  margin-top: 8rem;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  justify-content: space-between
}
.l-page--about .section__content {
  font-size: 1.6rem;
  line-height: 2;
  color: #7d7d7d;
  border-top: 1px solid #d0d0d0
}
.l-page--about .section__content dl {
  font-size: 1.6rem;
  display: -webkit-box;
  display: flex
}
.l-page--about .section__content dt {
  width: 100%;
  max-width: 12rem
}
.l-page--about .section__content dd {
  -webkit-box-flex: 1;
  flex: 1
}
.l-page--about .section__content .sub-text p {
  font-size: 1.4rem;
  line-height: 1.75
}
.l-page--download .section-archive {
  margin: 0 2rem
}
.l-page--download .section-archive li {
  border-radius: 10rem
}
.l-page--download .section-archive a {
  padding: 1.5rem 6rem
}
.l-page--facility {
  overflow: hidden
}
.l-page--facility .section-archive {
  padding: 0 2rem 12rem
}
.l-page--facility .section-archive__head {
  font-size: 1.6rem;
  font-weight: 700;
  position: relative;
  margin: 0 0 3rem;
  padding: 0 0 2.5rem;
  text-align: center;
  color: #7d7d7d
}
.l-page--facility .section-archive__head:before {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  width: 68px;
  height: 12px;
  margin: auto;
  content: '';
  border-radius: 4px;
  background: #f39800
}
.l-page--facility .section-archive__lead {
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 2.8rem;
  margin: 0 0 3rem;
  color: #7d7d7d
}
.l-page--facility .section-archive__select {
  margin: 0 0 6rem
}
.l-page--facility .section-archive__select select {
  font-size: 1.8rem;
  font-weight: 700;
  width: 100%;
  height: 5rem;
  padding: 0 2.5rem;
  color: #7d7d7d;
  border: none;
  border-radius: 8px;
  background: #f5f5f5 url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/facility/icon-select.png) no-repeat center right 25px/12px 7px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none
}
.l-page--facility .section-archive__category {
  display: none
}
.l-page--facility .section-archive__category ul {
  display: -webkit-box;
  display: flex;
  border-radius: 24px;
  background: #f5f5f5;
  justify-content: space-around
}
.l-page--facility .section-archive__category a {
  display: -webkit-box;
  display: flex;
  height: 10rem;
  -webkit-box-align: center;
  align-items: center
}
.l-page--facility .section-archive__category span {
  font-size: 1.8rem;
  font-weight: 700;
  position: relative;
  color: rgba(125, 125, 125, .5)
}
.l-page--facility .section-archive__category span:before {
  position: absolute;
  bottom: -2px;
  left: 0;
  visibility: hidden;
  width: 100%;
  height: 2px;
  content: '';
  opacity: 0;
  border-radius: 2px;
  background: #7d7d7d
}
.l-page--facility .section-archive__category .is-current span {
  color: #7d7d7d
}
.l-page--facility .section-archive__category .is-current span:before {
  visibility: visible;
  opacity: 1
}
.l-page--facility .section-archive__post {
  padding: 0 2rem
}
.l-page--facility .section-archive__item {
  margin: 0 0 4rem
}
.l-page--facility .section-archive__link {
  display: block
}
.l-page--facility .section-archive__thumb {
  position: relative;
  overflow: hidden;
  margin: 0 0 2.4rem;
  padding-top: calc(24 / 30 * 100%);
  border-radius: 10px
}
.l-page--facility .section-archive__thumb img {
  font-family: 'object-fit: cover; object-position: center;';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center
}
.l-page--facility .section-archive__cat {
  margin: 0 0 1.8rem;
  text-align: center
}
.l-page--facility .section-archive__cat span {
  font-family: Roboto, sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  display: inline-block;
  padding: .6rem 3rem;
  color: #fff;
  border-radius: 12px;
  background: #f39800
}
.l-page--facility .section-archive__title {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 3rem;
  text-align: center;
  color: #7d7d7d
}
.l-page--facility .section-archive__btn {
  font-size: 1.3rem;
  position: relative;
  display: -webkit-box;
  display: flex;
  width: 100%;
  max-width: 24rem;
  height: 5rem;
  margin: 0 auto;
  color: #7d7d7d;
  border: 4px solid #d2d2d2;
  border-radius: 25px;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  justify-content: center
}
.l-page--facility .section-archive__btn:before {
  position: absolute;
  top: 0;
  right: 2.5rem;
  bottom: 0;
  width: .5rem;
  height: .5rem;
  margin: auto;
  content: '';
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg);
  border-bottom: 1.5px solid #2aacf2;
  border-left: 1.5px solid #2aacf2
}
.l-page--facility .section-archive__btn.done {
  display: none
}
.l-page--facility .section-hero__thumb {
  height: 28rem;
  background-image: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/facility/main-image02.jpg);
  background-position: center;
  background-size: cover
}
.l-page--facility .section-hero__title {
  position: relative;
  padding: 0 2rem;
  text-align: center
}
.l-page--facility .section-hero__title:before {
  position: absolute;
  top: .1rem;
  left: 50%;
  width: calc(100% - 4rem);
  height: 4rem;
  content: '';
  -webkit-transform: translate(-50%, -100%);
  transform: translate(-50%, -100%);
  border-radius: 3rem 3rem 0 0;
  background: #fff
}
.l-page--facility .section-hero__title span {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 3.8rem;
  position: relative;
  color: #f39800
}
.l-page--facility .section-news {
  padding: 5rem 2rem 0
}
.l-page--facility .section-news__container {
  padding: 4rem 2rem;
  border-radius: 24px;
  background: #f5f5f5
}
.l-page--facility .section-news__head {
  font-size: 1.8rem;
  font-weight: 700;
  margin: 0 0 2rem;
  text-align: center;
  color: #f39800
}
.l-page--facility .section-news__list {
  margin: 0 0 4rem
}
.l-page--facility .section-news__list li {
  margin: 0 0 2rem
}
.l-page--facility .section-news__list li:last-child {
  margin: 0
}
.l-page--facility .section-news__list time {
  font-family: Roboto, sans-serif;
  font-size: 1.2rem;
  font-style: italic;
  display: block;
  margin: 0 0 1rem;
  color: #7d7d7d
}
.l-page--facility .section-news__list a {
  font-size: 1.4rem;
  line-height: 2.5rem;
  text-decoration: underline;
  color: #7d7d7d
}
.l-page--facility .section-point {
  padding: 8rem 2rem 0
}
.l-page--facility .section-point__head {
  font-size: 2rem;
  font-weight: 700;
  margin: 0 0 2rem;
  text-align: center;
  color: #f39800
}
.l-page--facility .section-point__lead {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 4.3rem;
  color: #7d7d7d
}
.l-page--facility .section-gallery {
  padding: 8rem 2rem 0
}
.l-page--facility .section-gallery__head {
  font-size: 2rem;
  font-weight: 700;
  margin: 0 0 3rem;
  text-align: center;
  color: #f39800
}
.l-page--facility .section-gallery__body {
  position: relative
}
.l-page--facility .section-gallery__body img {
  width: 100%;
  border-radius: 20px
}
.l-page--facility .section-gallery__body .swiper-slide span {
  font-size: 1.8rem;
  line-height: 2.8rem;
  display: block;
  padding: 2rem;
  text-align: center;
  color: #7d7d7d
}
.l-page--facility .section-gallery__body .swiper-pagination {
  right: 0;
  left: 0;
  margin: auto
}
.l-page--facility .section-gallery__body .swiper-pagination-bullet {
  width: 1rem;
  height: 1rem;
  margin: 0 .7rem;
  opacity: 1;
  background: #d0d0d0
}
.l-page--facility .section-gallery__body .swiper-pagination-bullet-active {
  background: #f39800
}
.l-page--facility .section-gallery__body .swiper-button-next, .l-page--facility .section-gallery__body .swiper-button-prev {
  margin-top: -5rem;
  color: #7d7d7d;
  outline: 0
}
.l-page--facility .section-gallery__body .swiper-button-next:after, .l-page--facility .section-gallery__body .swiper-button-prev:after {
  font-size: 1.8rem
}
.l-page--facility .section-gallery__body .swiper-button-prev {
  left: -2.3rem
}
.l-page--facility .section-gallery__body .swiper-button-next {
  right: -2.3rem
}
.l-page--facility .section-about {
  padding: 8rem 2rem 0
}
.l-page--facility .section-about__block:last-child {
  padding: 8rem 0 0
}
.l-page--facility .section-about__head {
  font-size: 2rem;
  font-weight: 700;
  margin: 0 0 2rem;
  text-align: center;
  color: #f39800
}
.l-page--facility .section-about__body h3, .l-page--facility .section-about__body p, .l-page--facility .section-about__body ul {
  font-size: 1.6rem;
  line-height: 2.8rem;
  color: #7d7d7d
}
.l-page--facility .section-about__body p, .l-page--facility .section-about__body ul {
  margin: 0 0 2rem
}
.l-page--facility .section-about__body p:last-child, .l-page--facility .section-about__body ul:last-child {
  margin: 0
}
.l-page--facility .section-about__body li {
  position: relative;
  padding: 0 0 0 2rem
}
.l-page--facility .section-about__body li:before {
  position: absolute;
  top: 0;
  left: 0;
  content: '■'
}
.l-page--facility .section-about__body small {
  font-size: 1.2rem;
  line-height: 1.8rem;
  display: block
}
.l-page--facility .section-about__btn {
  margin: 2rem 0 0
}
.l-page--facility .section-about__btn p {
  margin: 0 0 2em
}
.l-page--facility .section-about__btn a {
  font-size: 1.8rem
}
.l-page--facility .section-about__btn i {
  width: 30px;
  height: 30px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%)
}
.l-page--facility .section-access {
  padding: 8rem 2rem 0
}
.l-page--facility .section-access__head {
  font-size: 2rem;
  font-weight: 700;
  margin: 0 0 3rem;
  text-align: center;
  color: #f39800
}
.l-page--facility .section-access__body {
  margin: 0 0 2rem
}
.l-page--facility .section-access__body iframe {
  width: 100%;
  height: 40rem
}
.l-page--facility .section-access__add {
  font-size: 1.6rem;
  line-height: 2.8rem;
  color: #7d7d7d
}
.l-page--facility .section-future {
  padding: 8rem 2rem 0
}
.l-page--facility .section-future__head {
  font-size: 2rem;
  font-weight: 700;
  margin: 0 0 3rem;
  text-align: center;
  color: #f39800
}
.l-page--facility .section-future__block {
  margin: 0 0 3rem
}
.l-page--facility .section-future__block:last-child {
  margin: 0
}
.l-page--facility .section-future__thumb {
  overflow: hidden;
  margin: 0 0 2rem;
  border-radius: 20px
}
.l-page--facility .section-future__content h3 {
  font-size: 2rem;
  font-weight: 700;
  line-height: 3.6rem;
  margin: 0 0 2rem;
  color: #7d7d7d
}
.l-page--facility .section-future__content p {
  font-size: 1.6rem;
  line-height: 2.8rem;
  color: #7d7d7d
}
.l-page--facility .button-return {
  padding: 8rem 2rem
}
.l-page--contact {
  padding-bottom: 10rem
}
.l-page--contact .form-wrap {
  margin-top: 4rem;
  padding-top: 4rem;
  color: #7d7d7d;
  border-top: 1px solid #d0d0d0
}
.l-page--contact .form-wrap dl {
  display: -webkit-box;
  display: flex
}
.l-page--contact .form-wrap dl + dl {
  margin-top: 5rem
}
.l-page--contact .form-wrap dt {
  font-size: 1.6rem
}
.l-page--contact .form-wrap dt:after {
  margin: 0 0 0 .5rem;
  content: '*';
  color: #f39800
}
.l-page--contact .form-wrap dd {
  position: relative;
  min-height: 5.5rem;
  border-radius: .8rem;
  background: rgba(125, 125, 125, .1);
  -webkit-box-flex: 1;
  flex: 1
}
.l-page--contact .form-wrap dd span[role=alert] {
  position: absolute;
  bottom: -1rem;
  left: 0;
  -webkit-transform: translateY(100%);
  transform: translateY(100%);
  color: red
}
.l-page--contact .form-wrap input:not([type=submit]) {
  position: absolute;
  top: 0;
  left: 0
}
.l-page--contact .form-wrap input:not([type=submit]), .l-page--contact .form-wrap textarea {
  font-size: 1.6rem;
  width: 100%;
  height: 100%;
  padding: .5em 1em;
  border: none
}
.l-page--contact .contact__message {
  text-align: center
}
.l-page--contact .submit-btn {
  margin: 6rem 0 0;
  text-align: center
}
.l-page--contact .submit-btn input {
  font-size: 1.6rem;
  width: 20.8rem;
  padding: 1rem 0;
  color: #fff;
  border: none;
  border-radius: 2.5rem;
  background: #2aacf2
}
.l-page--contact .screen-reader-response {
  font-size: 1.6rem;
  line-height: 1.7;
  margin-bottom: 4rem;
  text-align: center;
  color: red
}
.l-page--contact .screen-reader-response ul {
  display: none
}
.l-page--contact .wpcf7-response-output {
  display: none
}
.l-page--info {
  overflow: hidden
}
.l-page--info .section-hero {
  padding: 9rem 2rem 0
}
.l-page--info .section-hero h1 {
  display: -webkit-box;
  display: flex;
  padding: 0 0 2rem;
  border-bottom: 6px solid #d0d0d0;
  border-radius: 3px;
  -webkit-box-align: center;
  align-items: center
}
.l-page--info .section-hero span {
  font-weight: 700
}
.l-page--info .section-hero span:nth-child(1) {
  font-family: Roboto, sans-serif;
  font-size: .8rem;
  margin: 0 1.3rem 0 0;
  padding: .3rem 1rem;
  color: #f39800;
  border: 2px solid #f39800;
  border-radius: 30px
}
.l-page--info .section-hero span:nth-child(2) {
  font-size: 1.6rem;
  color: #7d7d7d
}
.l-page--info .section-info {
  padding: 7rem 2rem 0
}
.l-page--info .section-info__head {
  font-size: 2.4rem;
  font-weight: 700;
  margin: 0 0 3rem;
  text-align: center;
  color: #f39800
}
.l-page--info .section-info__body {
  border-top: 1px solid #d0d0d0
}
.l-page--info .section-info__body dl {
  padding: 1.5rem 0;
  border-bottom: 1px solid #d0d0d0
}
.l-page--info .section-info__body dt {
  font-size: 1.8rem;
  font-weight: 700;
  margin: 0 0 1rem;
  color: #2aacf2
}
.l-page--info .section-info__body dd {
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 2.5rem;
  color: #7d7d7d
}
.l-page--info .section-info__body li {
  position: relative;
  padding: 0 0 0 1.4rem
}
.l-page--info .section-info__body li:before {
  position: absolute;
  top: 0;
  left: 0;
  content: '・'
}
.l-page--info .section-faq {
  padding: 7rem 2rem 0
}
.l-page--info .section-faq__head {
  font-size: 2.4rem;
  font-weight: 700;
  margin: 0 0 3rem;
  text-align: center;
  color: #f39800
}
.l-page--info .section-faq__body {
  border-top: 6px solid #d0d0d0
}
.l-page--info .section-faq__body dl {
  border-bottom: 6px solid #d0d0d0
}
.l-page--info .section-faq__body dd, .l-page--info .section-faq__body dt {
  position: relative;
  color: #7d7d7d
}
.l-page--info .section-faq__body dd:before, .l-page--info .section-faq__body dt:before {
  font-size: 2.6rem;
  font-weight: 700;
  position: absolute;
  left: 1rem;
  color: #f39800
}
.l-page--info .section-faq__body dt {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 2.8rem;
  padding: 1.5rem 5rem
}
.l-page--info .section-faq__body dt:before {
  top: 1.5rem;
  content: 'Q'
}
.l-page--info .section-faq__body dd {
  font-size: 1.6rem;
  line-height: 2.5rem;
  display: none;
  padding: 0 5rem 1.5rem
}
.l-page--info .section-faq__body dd:before {
  top: 0;
  content: 'A'
}
.l-page--info .section-faq__body i {
  position: absolute;
  top: 1.5rem;
  right: 0;
  display: block;
  width: 30px;
  height: 30px;
  cursor: pointer;
  border-radius: 50%;
  background: #2aacf2
}
.l-page--info .section-faq__body i:before {
  position: absolute;
  top: 50%;
  left: 50%;
  width: .5rem;
  height: .5rem;
  content: '';
  -webkit-transform: translate(-50%, -50%) rotate(-135deg);
  transform: translate(-50%, -50%) rotate(-135deg);
  border-top: 1.5px solid #fff;
  border-left: 1.5px solid #fff
}
.l-page--info .section-faq__body ol {
  margin: 2rem 0 0
}
.l-page--info .section-faq__body li {
  font-size: 1.4rem;
  margin: 0 0 1rem
}
.l-page--info .section-faq__body li:last-child {
  margin: 0
}
.l-page--info .section-entry {
  padding: 14rem 2rem 11rem
}
.l-page--info .section-entry__container {
  position: relative;
  padding: 7rem 2rem;
  border: 8px solid #eff1eb;
  border-radius: 40px
}
.l-page--info .section-entry__content {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%)
}
.l-page--info .section-entry__head {
  font-size: 3.4rem;
  font-weight: 700;
  margin: 0 0 2.2rem;
  text-align: center;
  letter-spacing: .12rem;
  color: #f39800
}
.l-page--info .section-entry__lead {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 3rem;
  margin: 0 0 2rem;
  color: #7d7d7d
}
.l-page--info .section-entry__btn .btn--recruit:nth-child(1) {
  margin: 0 0 2rem
}
.l-page--news .news-list {
  margin: 0 2rem
}
.l-page--news .news-list__item {
  border-bottom: 6px solid #d0d0d0
}
.l-page--news .news-list__item:first-of-type {
  border-top: 6px solid #d0d0d0
}
.l-page--news .news-list__item a {
  position: relative;
  display: -webkit-box;
  display: flex;
  box-sizing: border-box;
  padding: 2.5em 4.8em 2.5em 0;
  color: #7d7d7d;
  flex-wrap: wrap;
  -webkit-box-align: center;
  align-items: center
}
.l-page--news .news-list__item a::before {
  position: absolute;
  top: 50%;
  right: 1rem;
  width: 30px;
  height: 30px;
  content: '';
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/news/arrow.png) no-repeat scroll center center/cover
}
.l-page--news .news-list__item a .-date {
  font-size: 1.2rem;
  width: 90px
}
.l-page--news .news-list__item a .-category {
  font-size: 1.4rem;
  font-weight: 700;
  width: 160px
}
.l-page--news .news-list__item a .-title {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.6;
  width: 100%;
  padding-top: .5em
}
.l-page--news .news-pagenation {
  margin: 4rem 0
}
.l-page--news .news-pagenation .page-numbers {
  display: -webkit-box;
  display: flex;
  list-style: none;
  -webkit-box-pack: center;
  justify-content: center;
  flex-wrap: wrap;
  -webkit-box-align: center;
  align-items: center
}
.l-page--news .news-pagenation .page-numbers li {
  padding: 0 .75rem
}
.l-page--news .news-pagenation .page-numbers li a {
  font-size: 2rem;
  font-weight: 700;
  color: #7d7d7d
}
.l-page--news .news-pagenation .page-numbers li span {
  font-size: 2rem;
  font-weight: 700
}
.l-page--news .news-pagenation .page-numbers li .current {
  color: #f39800
}
.l-page--news .news-pagenation .page-numbers li .prev {
  width: 30px;
  height: 30px;
  margin-right: 2rem;
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
  background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/news/arrow.png) no-repeat scroll center center/cover
}
.l-page--news .news-pagenation .page-numbers li .next {
  width: 30px;
  height: 30px;
  margin-left: 2rem;
  background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/news/arrow.png) no-repeat scroll center center/cover
}
.l-page--news .newslist {
  margin: 0 2rem;
  padding: 4rem 2rem;
  border-radius: 24px;
  background-color: #f3f6ef;
  box-shadow: 0 0 5px rgba(0, 0, 0, .15)
}
.l-page--news .newslist__item {
  display: -webkit-box;
  display: flex;
  padding: 4rem 0;
  border-top: 1px solid #d6d6d6;
  -webkit-box-pack: justify;
  justify-content: space-between;
  flex-wrap: wrap
}
.l-page--news .newslist__item:first-of-type {
  border-top: none
}
.l-page--news .newslist__item .-thumb {
  border-radius: 24px
}
.l-page--news .newslist__item .-textarea__data {
  font-family: Roboto, sans-serif;
  font-size: 1.2rem;
  font-weight: 300;
  color: #7d7d7d
}
.l-page--news .newslist__item .-textarea__ttl {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.6;
  padding: .5em 0;
  color: #7d7d7d
}
.l-page--news .newslist__item .-textarea__txt {
  font-size: 1.5rem;
  line-height: 1.8;
  color: #7d7d7d
}
.l-page--news .newslist__item .-textarea__more {
  font-size: 1.2rem;
  display: inherit;
  padding-top: 1rem;
  text-align: right;
  text-decoration: underline;
  color: #f39800
}
.l-page--news .newslist__continued {
  padding: 2rem 0;
  -webkit-transform: translate(-1.5em, 0);
  transform: translate(-1.5em, 0);
  text-align: center
}
.l-page--news .newslist__continued a {
  font-size: 2.2rem;
  font-weight: 700;
  position: relative;
  color: #f39800
}
.l-page--news .newslist__continued a:after {
  position: absolute;
  top: 50%;
  right: -1.6em;
  width: 28px;
  height: 28px;
  content: '';
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/news/arrow.png) no-repeat scroll center center/cover
}
.l-page--news .newsarticle {
  margin: 0 2rem;
  padding: 4rem 2rem;
  border: 6px solid #d0d0d0;
  border-radius: 24px
}
.l-page--news .newsarticle .-date {
  font-family: Roboto, sans-serif;
  font-size: 1.2rem;
  font-weight: 300;
  color: #7d7d7d
}
.l-page--news .newsarticle .-ttl {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.62;
  padding: .5em 0;
  letter-spacing: .09em;
  color: #f39800
}
.l-page--news .newsarticle .-complement {
  display: -webkit-box;
  display: flex;
  margin-bottom: 6rem;
  -webkit-box-align: center;
  align-items: center
}
.l-page--news .newsarticle .-complement__date {
  font-size: 1.3rem;
  padding-right: 2rem;
  letter-spacing: .07em;
  color: #7d7d7d
}
.l-page--news .newsarticle .-complement__category {
  font-size: 1.6rem;
  font-weight: 700;
  color: #7d7d7d
}
.l-page--news .newsarticle .-complement__category a {
  color: #7d7d7d
}
.l-page--news .newsarticle .-thumb {
  width: 100%;
  border-radius: 24px
}
.l-page--news .newsarticle .-thumb img {
  border-radius: 62px
}
.l-page--news .newsarticle .newsarticle__body {
  padding-top: 2rem
}
.l-page--news .newsarticle .newsarticle__body p {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.68;
  margin: 1.5em 0;
  color: #7d7d7d
}
.l-page--news .newsnavi {
  display: -webkit-box;
  display: flex;
  padding: 6rem 2rem 0 2rem;
  -webkit-box-pack: justify;
  justify-content: space-between
}
.l-page--news .newsnavi li a {
  font-size: 1.5rem;
  font-weight: 700;
  color: #f39800
}
.l-page--news .newsnavi .-prev {
  -webkit-transform: translate(1.6em, 0);
  transform: translate(1.6em, 0)
}
.l-page--news .newsnavi .-prev a {
  position: relative
}
.l-page--news .newsnavi .-prev a:after {
  position: absolute;
  top: 50%;
  left: -1.6em;
  width: 20px;
  height: 20px;
  content: '';
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/news/prev.png) no-repeat scroll center center/cover
}
.l-page--news .newsnavi .-next {
  -webkit-transform: translate(-1.6em, 0);
  transform: translate(-1.6em, 0)
}
.l-page--news .newsnavi .-next a {
  position: relative
}
.l-page--news .newsnavi .-next a:after {
  position: absolute;
  top: 50%;
  right: -1.6em;
  width: 20px;
  height: 20px;
  content: '';
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/news/next.png) no-repeat scroll center center/cover
}
.l-page--recruit {
  overflow: hidden
}
.l-page--recruit .section-hero {
  display: -webkit-box;
  display: flex;
  height: 40rem;
  background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/recruit/main-image01.jpg) no-repeat center bottom/cover;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  justify-content: center
}
.l-page--recruit .section-hero__title {
  visibility: hidden;
  width: 28rem;
  -webkit-transition: .5s .5s cubic-bezier(.175, .885, .32, 1.275);
  transition: .5s .5s cubic-bezier(.175, .885, .32, 1.275);
  -webkit-transform: translateY(20px) scale(.8);
  transform: translateY(20px) scale(.8);
  opacity: 0
}
.l-page--recruit .section-hero__title.is-show {
  visibility: visible;
  -webkit-transform: translateY(0) scale(1);
  transform: translateY(0) scale(1);
  opacity: 1
}
.l-page--recruit .section-philosophy {
  padding: 2rem 1rem 0
}
.l-page--recruit .section-philosophy__body {
  position: relative
}
.l-page--recruit .section-philosophy__illust {
  display: none
}
.l-page--recruit .section-philosophy__illust li {
  position: absolute;
  visibility: hidden;
  -webkit-transition: .6s cubic-bezier(.175, .885, .32, 1.275);
  transition: .6s cubic-bezier(.175, .885, .32, 1.275);
  -webkit-transform: translate(-20px, 80px) rotate(-15deg);
  transform: translate(-20px, 80px) rotate(-15deg);
  opacity: 0
}
.l-page--recruit .section-philosophy__illust li:nth-child(1) {
  top: -7rem;
  right: 13rem;
  width: 21.1rem
}
.l-page--recruit .section-philosophy__illust li:nth-child(2) {
  top: 34rem;
  left: 40rem;
  width: 13.3rem
}
.l-page--recruit .section-philosophy__illust li:nth-child(3) {
  top: 47rem;
  left: -3rem;
  width: 15.3rem
}
.l-page--recruit .section-philosophy__illust li:nth-child(4) {
  top: 47rem;
  right: -3rem;
  width: 15.9rem
}
.l-page--recruit .section-philosophy__illust li:nth-child(5) {
  top: 70rem;
  right: 17rem;
  width: 26rem
}
.l-page--recruit .section-philosophy__illust li.is-show {
  visibility: visible;
  -webkit-transform: translate(0, 0) rotate(0);
  transform: translate(0, 0) rotate(0);
  opacity: 1
}
.l-page--recruit .section-philosophy__btn {
  width: 29.6rem;
  margin: 4rem auto 0
}
.l-page--recruit .section-business {
  padding: 8rem 1rem 0
}
.l-page--recruit .section-business__title {
  font-size: 3rem;
  font-weight: 700;
  line-height: 4.9rem;
  margin: 0 0 3.8rem;
  text-align: center;
  letter-spacing: .14rem;
  color: #7d7d7d
}
.l-page--recruit .section-business__body {
  position: relative
}
.l-page--recruit .section-business__illust {
  display: none
}
.l-page--recruit .section-business__illust li {
  position: absolute;
  visibility: hidden;
  -webkit-transition: .6s cubic-bezier(.175, .885, .32, 1.275);
  transition: .6s cubic-bezier(.175, .885, .32, 1.275);
  -webkit-transform: translate(-20px, 80px) rotate(-15deg);
  transform: translate(-20px, 80px) rotate(-15deg);
  opacity: 0
}
.l-page--recruit .section-business__illust li:nth-child(1) {
  top: 19rem;
  left: -4rem;
  width: 43rem
}
.l-page--recruit .section-business__illust li:nth-child(2) {
  top: 67rem;
  right: 23rem;
  width: 18.9rem
}
.l-page--recruit .section-business__illust li:nth-child(3) {
  top: 87rem;
  right: 18rem;
  width: 23.1rem
}
.l-page--recruit .section-business__illust li.is-show {
  visibility: visible;
  -webkit-transform: translate(0, 0) rotate(0);
  transform: translate(0, 0) rotate(0);
  opacity: 1
}
.l-page--recruit .section-business__btn {
  width: 29.6rem;
  margin: 4rem auto 0
}
.l-page--recruit .section-topics {
  position: relative;
  padding: 14rem 4rem 0
}
.l-page--recruit .section-topics__content {
  position: absolute;
  top: 5%;
  left: 50%;
  width: 90%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%)
}
.l-page--recruit .section-topics__head {
  margin: 0 0 1rem
}
.l-page--recruit .section-topics__head span {
  font-weight: 700;
  display: block;
  text-align: center;
  letter-spacing: .12rem
}
.l-page--recruit .section-topics__head span:nth-child(1) {
  font-family: Roboto, sans-serif;
  font-size: 1.6rem;
  margin: 0 0 1rem;
  color: #f39800
}
.l-page--recruit .section-topics__head span:nth-child(2) {
  font-size: 3.4rem;
  color: #7d7d7d
}
.l-page--recruit .section-topics__lead {
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 2.5rem;
  margin: 0 0 3rem;
  text-align: center;
  color: #7d7d7d
}
.l-page--recruit .section-topics__item {
  margin: 0 0 5rem
}
.l-page--recruit .section-topics__link {
  display: block
}
.l-page--recruit .section-topics__thumb {
  position: relative;
  overflow: hidden;
  margin: 0 0 2.4rem;
  padding-top: calc(24 / 30 * 100%);
  border-radius: 10px
}
.l-page--recruit .section-topics__thumb img {
  font-family: 'object-fit: cover; object-position: center;';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center
}
.l-page--recruit .section-topics__cat {
  margin: 0 0 2.2rem;
  text-align: center
}
.l-page--recruit .section-topics__cat span {
  font-family: Roboto, sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  display: inline-block;
  padding: .6rem 3rem;
  color: #fff;
  border-radius: 12px;
  background: #f39800
}
.l-page--recruit .section-topics__title {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 3rem;
  text-align: center;
  color: #7d7d7d
}
.l-page--recruit .section-info {
  position: relative;
  padding: 19rem 4rem 0
}
.l-page--recruit .section-info__content {
  position: absolute;
  top: 32%;
  left: 50%;
  width: 90%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%)
}
.l-page--recruit .section-info__head {
  margin: 0 0 1rem
}
.l-page--recruit .section-info__head span {
  font-weight: 700;
  display: block;
  text-align: center;
  letter-spacing: .12rem
}
.l-page--recruit .section-info__head span:nth-child(1) {
  font-family: Roboto, sans-serif;
  font-size: 1.6rem;
  margin: 0 0 1rem;
  color: #f39800
}
.l-page--recruit .section-info__head span:nth-child(2) {
  font-size: 3.4rem;
  color: #7d7d7d
}
.l-page--recruit .section-info__lead {
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 2.5rem;
  margin: 0 0 3rem;
  text-align: center;
  color: #7d7d7d
}
.l-page--recruit .section-entry {
  padding: 14rem 2rem 11rem
}
.l-page--recruit .section-entry__container {
  position: relative;
  padding: 7rem 2rem;
  border: 8px solid #eff1eb;
  border-radius: 40px
}
.l-page--recruit .section-entry__content {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%)
}
.l-page--recruit .section-entry__head {
  font-size: 3.4rem;
  font-weight: 700;
  margin: 0 0 2.2rem;
  text-align: center;
  letter-spacing: .12rem;
  color: #f39800
}
.l-page--recruit .section-entry__lead {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 3rem;
  margin: 0 0 2rem;
  color: #7d7d7d
}
.l-page--recruit .section-entry__btn .btn--recruit:nth-child(1) {
  margin: 0 0 2rem
}
.l-page--service .card-wrap {
  display: -webkit-box;
  display: flex;
  -webkit-box-pack: justify;
  justify-content: space-between;
  flex-wrap: wrap
}
.l-page--top {
  overflow: hidden;
  padding: 0 0 12rem
}
.l-page--top .message-section {
  position: relative;
  padding: 9rem 2rem 12rem
}
.l-page--top .message-section p {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 2.13;
  color: #7d7d7d
}
.l-page--top .section-image {
  margin-top: 3.5rem;
  text-align: center
}
.l-page--top .btn-list {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 63rem;
  margin-right: auto;
  margin-left: auto
}
.l-page--top .btn--primary, .l-page--top .btn--secondary, .l-page--top .btn-list {
  margin-top: 3.5rem
}
.l-page--top .btn-list .btn--primary {
  margin-top: 1em
}
.l-page--top .btn--secondary {
  width: 100%;
  max-width: 22rem;
  margin-right: auto;
  margin-left: auto
}
.l-page--top .l-section--o, .l-page--top .l-section--w {
  margin-top: 6rem;
  padding: 5.5rem 2rem 7rem
}
.l-page--top .l-section--o .section-description, .l-page--top .l-section--o .section-title, .l-page--top .l-section--o .section-title--secondary, .l-page--top .l-section--t .section-description, .l-page--top .l-section--t .section-title, .l-page--top .l-section--t .section-title--secondary {
  color: #fff
}
.l-page--top .l-section--o .section-title--secondary span:nth-child(1) {
  font-size: 2.4rem;
  display: block;
  color: #fff
}
.l-page--top .l-section--o .section-title--secondary span:nth-child(2):after {
  background: #fff
}
.l-page--top .l-section--o .section-description {
  margin-top: 3.5rem
}
.l-page--top .l-section--t {
  margin-top: 6rem
}
.l-page--top .recruit-section {
  position: relative
}
.l-page--top .recruit-section .bg-image {
  position: absolute;
  top: 11.5rem;
  left: 50%;
  width: 100%;
  -webkit-transition: .6s;
  transition: .6s;
  -webkit-transform: translate(-50%, -100%) scale(1.1);
  transform: translate(-50%, -100%) scale(1.1);
  opacity: 0
}
.l-page--top .recruit-section .bg-image.is-show {
  -webkit-transform: translate(-50%, -100%) scale(1);
  transform: translate(-50%, -100%) scale(1);
  opacity: 1
}
.l-page--top .service-flow {
  margin-top: 5rem
}
.l-page--top .service-flow dt {
  font-size: 1.6rem;
  font-weight: 700;
  text-align: center;
  color: #f39800
}
.l-page--topics {
  overflow: hidden
}
.l-page--topics .section-hero {
  padding: 9rem 2rem 0
}
.l-page--topics .section-hero h1 {
  display: -webkit-box;
  display: flex;
  padding: 0 0 2rem;
  border-bottom: 6px solid #d0d0d0;
  border-radius: 3px;
  -webkit-box-align: center;
  align-items: center
}
.l-page--topics .section-hero span {
  font-weight: 700
}
.l-page--topics .section-hero span:nth-child(1) {
  font-family: Roboto, sans-serif;
  font-size: .8rem;
  margin: 0 1.3rem 0 0;
  padding: .3rem 1rem;
  color: #f39800;
  border: 2px solid #f39800;
  border-radius: 30px
}
.l-page--topics .section-hero span:nth-child(2) {
  font-size: 1.6rem;
  color: #7d7d7d
}
.l-page--topics .section-info {
  padding: 6rem 2rem 0
}
.l-page--topics .section-info__head {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 3rem;
  margin: 0 0 3rem;
  text-align: center;
  color: #7d7d7d
}
.l-page--topics .section-info__category {
  display: -webkit-box;
  display: flex;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  justify-content: center
}
.l-page--topics .section-info__category p {
  font-size: 1.3rem;
  font-weight: 700;
  margin: 0 1.5rem 0 0;
  color: #7d7d7d
}
.l-page--topics .section-info__category select {
  font-size: 1.8rem;
  font-weight: 700;
  width: 100%;
  height: 5rem;
  padding: 0 2.5rem;
  color: #7d7d7d;
  border: none;
  border-radius: 8px;
  background: #f5f5f5 url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/topics/icon-select.png) no-repeat center right 25px/12px 7px;
  -webkit-box-flex: 1;
  flex: 1;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none
}
.l-page--topics .section-archive {
  padding: 6rem 4rem 0
}
.l-page--topics .section-archive__item {
  margin: 0 0 5rem
}
.l-page--topics .section-archive__link {
  display: block
}
.l-page--topics .section-archive__thumb {
  position: relative;
  overflow: hidden;
  margin: 0 0 2.4rem;
  padding-top: calc(24 / 30 * 100%);
  border-radius: 10px
}
.l-page--topics .section-archive__thumb img {
  font-family: 'object-fit: cover; object-position: center;';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center
}
.l-page--topics .section-archive__cat {
  margin: 0 0 2.2rem;
  text-align: center
}
.l-page--topics .section-archive__cat span {
  font-family: Roboto, sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  display: inline-block;
  padding: .6rem 3rem;
  color: #fff;
  border-radius: 12px;
  background: #f39800
}
.l-page--topics .section-archive__title {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 3rem;
  text-align: center;
  color: #7d7d7d
}
.l-page--topics .section-entry {
  padding: 14rem 2rem 11rem
}
.l-page--topics .section-entry__container {
  position: relative;
  padding: 7rem 2rem;
  border: 8px solid #eff1eb;
  border-radius: 40px
}
.l-page--topics .section-entry__content {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%)
}
.l-page--topics .section-entry__head {
  font-size: 3.4rem;
  font-weight: 700;
  margin: 0 0 2.2rem;
  text-align: center;
  letter-spacing: .12rem;
  color: #f39800
}
.l-page--topics .section-entry__lead {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 3rem;
  margin: 0 0 2rem;
  color: #7d7d7d
}
.l-page--topics .section-entry__btn .btn--recruit:nth-child(1) {
  margin: 0 0 2rem
}
.l-page--topics .section-single {
  padding: 5rem 2rem 10rem
}
.l-page--topics .section-single__thumb {
  overflow: hidden;
  margin: 0 0 3rem;
  border-radius: 20px
}
.l-page--topics .section-single__content h1, .l-page--topics .section-single__content h2, .l-page--topics .section-single__content h3, .l-page--topics .section-single__content h4, .l-page--topics .section-single__content h5, .l-page--topics .section-single__content h6, .l-page--topics .section-single__content ol, .l-page--topics .section-single__content p, .l-page--topics .section-single__content ul {
  font-size: 1.6rem;
  line-height: 1.8;
  margin: 2rem 0;
  color: #7d7d7d
}
.l-page--topics .section-single__content h1, .l-page--topics .section-single__content h2, .l-page--topics .section-single__content h3, .l-page--topics .section-single__content h4, .l-page--topics .section-single__content h5, .l-page--topics .section-single__content h6 {
  font-weight: 700
}
.l-page--topics .section-single__content h1 {
  font-size: 3rem;
  color: #f39800
}
.l-page--topics .section-single__content h2, .l-page--topics .section-single__content h3, .l-page--topics .section-single__content h4, .l-page--topics .section-single__content h5, .l-page--topics .section-single__content h6 {
  font-size: 2.2rem;
  color: #7d7d7d
}
.l-page--topics .section-single__content img {
  border-radius: 20px
}
.l-page--topics .section-single__pager {
  display: -webkit-box;
  display: flex;
  padding: 4rem 0 0;
  -webkit-box-pack: justify;
  justify-content: space-between
}
.l-page--topics .section-single__pager a {
  font-size: 1.2rem;
  font-weight: 700;
  position: relative;
  display: block;
  color: #7d7d7d
}
.l-page--topics .section-single__pager a:before {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 30px;
  height: 30px;
  margin: auto;
  content: ''
}
.l-page--topics .section-single__pager .prev a {
  padding: 0 0 0 4rem
}
.l-page--topics .section-single__pager .prev a:before {
  left: 0;
  background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/topics/prev.png) center/cover
}
.l-page--topics .section-single__pager .next a {
  padding: 0 4rem 0 0
}
.l-page--topics .section-single__pager .next a:before {
  right: 0;
  background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/topics/next.png) center/cover
}
.l-page--topics .section-relation {
  padding: 0 2rem
}
.l-page--topics .section-relation__container {
  padding: 8rem 0 0;
  border-top: 6px solid #d0d0d0;
  border-radius: 3px
}
.l-page--topics .section-relation__head {
  font-size: 2.2rem;
  font-weight: 700;
  margin: 0 0 6rem;
  text-align: center;
  color: #f39800
}
.l-page--topics .section-relation__item {
  margin: 0 0 5rem
}
.l-page--topics .section-relation__link {
  display: block
}
.l-page--topics .section-relation__thumb {
  position: relative;
  overflow: hidden;
  margin: 0 0 2.4rem;
  padding-top: calc(24 / 30 * 100%);
  border-radius: 10px
}
.l-page--topics .section-relation__thumb img {
  font-family: 'object-fit: cover; object-position: center;';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center
}
.l-page--topics .section-relation__cat {
  margin: 0 0 2.2rem;
  text-align: center
}
.l-page--topics .section-relation__cat span {
  font-family: Roboto, sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  display: inline-block;
  padding: .6rem 3rem;
  color: #fff;
  border-radius: 12px;
  background: #f39800
}
.l-page--topics .section-relation__title {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 3rem;
  text-align: center;
  color: #7d7d7d
}
.l-page--topics .news-pagenation {
  margin: 4rem 0
}
.l-page--topics .news-pagenation .page-numbers {
  display: -webkit-box;
  display: flex;
  list-style: none;
  -webkit-box-pack: center;
  justify-content: center;
  flex-wrap: wrap;
  -webkit-box-align: center;
  align-items: center
}
.l-page--topics .news-pagenation .page-numbers li {
  padding: 0 .75rem
}
.l-page--topics .news-pagenation .page-numbers a {
  font-size: 2rem;
  font-weight: 700;
  color: #7d7d7d
}
.l-page--topics .news-pagenation .page-numbers span {
  font-size: 2rem;
  font-weight: 700
}
.l-page--topics .news-pagenation .page-numbers .current {
  color: #f39800
}
.l-page--topics .news-pagenation .page-numbers .prev {
  width: 30px;
  height: 30px;
  margin-right: 2rem;
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
  background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/news/arrow.png) no-repeat scroll center center/cover
}
.l-page--topics .news-pagenation .page-numbers .next {
  width: 30px;
  height: 30px;
  margin-left: 2rem;
  background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/news/arrow.png) no-repeat scroll center center/cover
}
@media print, screen and (min-width:768px) {
  a {
    -webkit-transition: opacity .3s;
    transition: opacity .3s
  }
  a:hover {
    opacity: .7
  }
  a.is-disable:hover {
    opacity: 1
  }
  .link--back {
    margin: 9rem 0 0
  }
  .is-sp {
    display: none
  }
  body.body--top .l-header--top {
    -webkit-transform: translate(-50%, -200%);
    transform: translate(-50%, -200%)
  }
  body.body--top .l-header--top.is-show {
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0)
  }
  body.body--top .page__movie {
    opacity: 0
  }
  body.body--top .icon-wrap--face .icon--face {
    -webkit-transform: translateY(6rem);
    transform: translateY(6rem);
    opacity: 0
  }
  body.body--top.is-init {
    overflow: hidden;
    height: 100vh
  }
  body.body--top.is-init .l-header--top {
    -webkit-transition: .8s;
    transition: .8s
  }
  body.body--top.is-init .page__movie {
    opacity: 1
  }
  body.body--top.is-init .icon-wrap--face .icon--face {
    -webkit-transition: 1s .1s;
    transition: 1s .1s
  }
  body.body--top .icon-wrap--face.is-show .icon--face {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    opacity: 1
  }
  body.body--top.is-loaded .page__movie {
    opacity: 1
  }
  body {
    min-width: 1000px
  }
  .l-content {
    width: calc(100% - 20rem)
  }
  .l-content--curves {
    padding-top: 3rem
  }
  .l-content--curves:before {
    width: 100%;
    max-width: 100rem;
    height: 6rem;
    border-radius: 6rem 6rem 0 0
  }
  .l-content--newslist {
    padding-bottom: 10rem
  }
  .l-content--newsarticle {
    padding: 28rem 0 10rem 0
  }
  .l-section--o, .l-section--w {
    width: calc(100% - 20rem)
  }
  .l-section--t {
    width: calc(100% - 20rem)
  }
  .l-page--about .section-title--page, .l-page--service .section-title--page {
    margin-top: 5.5rem
  }
  .l-page--about .section-lead, .l-page--about .section-textarea, .l-page--service .section-lead, .l-page--service .section-textarea {
    width: 100%;
    margin-right: auto;
    margin-left: auto
  }
  .l-page--about .section-lead, .l-page--about .section-textarea, .l-page--service .section-lead, .l-page--service .section-textarea {
    max-width: 82.4rem;
    margin-top: 5.5rem
  }
  .l-page--about .section-lead, .l-page--service .section-lead {
    max-width: 82.4rem;
    margin: 5.5rem auto 10em auto
  }
  .l-page--about .section-lead, .l-page--about .section-textarea {
    max-width: 100rem;
    padding-left: 8.8rem
  }
  .btn--comingsoon:after {
    font-size: 1.8rem
  }
  .l-footer {
    padding: 12rem 0
  }
  .l-footer .footer__bg {
    top: 0;
    right: 0;
    bottom: 0;
    -webkit-transition: .8s;
    transition: .8s;
    -webkit-transform: translateY(10rem);
    transform: translateY(10rem);
    opacity: 0;
    background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/bg-footer.png) no-repeat center bottom;
    background-size: 100% auto
  }
  .l-footer .footer__bg.is-show {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    opacity: 1
  }
  .l-footer aside {
    padding: 6rem 5rem 8rem
  }
  .l-footer .aside__row:before {
    top: 0;
    left: 50%;
    width: .1rem;
    height: 100%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%)
  }
  .l-footer .aside__row section {
    width: calc(100% / 2);
    max-width: 31rem
  }
  .l-footer .aside__row section:first-child {
    padding-left: 1rem
  }
  .l-footer .menu {
    margin-top: 29rem
  }
  .l-header-recruit {
    padding: 4rem 14rem 4rem 4rem
  }
  .l-header-recruit .header__logo {
    max-width: 14rem
  }
  .l-header-recruit .header__desc {
    margin: 0 0 0 2rem
  }
  .l-header-recruit .header__desc i {
    width: .7rem
  }
  .l-header-recruit .header__desc span {
    font-size: 1.5rem;
    padding: 0 1rem
  }
  .l-header-recruit .header__entry {
    position: fixed;
    top: 4rem;
    right: 15rem;
    display: block;
    width: 21rem;
    border-radius: 24px
  }
  .l-header-recruit .header__nav .header__nav__inner {
    width: 50%;
    margin: 0 auto
  }
  .l-header-recruit .header__nav .header__nav__inner div:nth-child(1) {
    margin: 0 0 5rem
  }
  .l-header-recruit .header__nav .header__nav__inner div:nth-child(1) li {
    margin: 0 0 3rem
  }
  .l-header-recruit .header__nav .header__nav__inner div:nth-child(1) a {
    font-size: 3rem
  }
  .l-header-recruit .header__nav .header__nav__inner div:nth-child(2) {
    border-radius: 40px
  }
  .l-header-recruit .header__nav .header__nav__inner div:nth-child(2) p {
    font-size: 2rem
  }
  .l-header-recruit .header__nav .header__nav__inner div:nth-child(2) li {
    margin: 0 0 3rem
  }
  .l-header-recruit .header__nav .header__nav__inner div:nth-child(2) a {
    font-size: 3rem
  }
  .l-header-recruit .header__opener {
    top: 1rem;
    right: 2rem;
    width: 11rem;
    height: 9.7rem;
    cursor: pointer
  }
  .l-header {
    position: fixed;
    z-index: 40;
    top: 5.5rem;
    left: 50%;
    min-width: 90rem;
    max-width: 90%;
    padding: 4rem 6rem;
    padding: 4rem 20rem 4rem 6rem;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    border-radius: 1rem;
    background: #fff;
    box-shadow: 0 0 5px rgba(0, 0, 0, .15)
  }
  .l-header .header__logo {
    max-width: 10rem
  }
  .l-header .header__nav {
    -webkit-box-flex: 1;
    flex: 1
  }
  .l-header .header__nav li {
    padding: 2rem 0
  }
  .l-header .header__nav li + li {
    margin: 0 0 0 2rem
  }
  .l-header .header__nav a {
    font-size: 1.4rem
  }
  .l-header .header__drawer > a {
    pointer-events: none
  }
  .l-header .header__drawer ul {
    position: absolute;
    top: 5rem;
    left: 0;
    visibility: hidden;
    width: 100%;
    -webkit-transition: .3s;
    transition: .3s;
    -webkit-transform: translateY(-1rem);
    transform: translateY(-1rem);
    opacity: 0
  }
  .l-header .header__drawer ul.active {
    visibility: visible;
    -webkit-transform: translateY(0);
    transform: translateY(0);
    opacity: 1
  }
  .l-header .header__drawer ul li {
    padding: 0
  }
  .l-header .header__button {
    position: absolute;
    top: 50%;
    right: 4.5rem;
    width: 16rem;
    height: 14rem;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%)
  }
  .l-header .header__button a {
    font-size: 1.4rem;
    display: -webkit-box;
    display: flex;
    width: 16rem;
    height: 14rem;
    -webkit-transition: .3s;
    transition: .3s;
    color: #fff;
    background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/icon-beans01.png) no-repeat;
    background-size: 100% auto;
    -webkit-box-align: center;
    align-items: center;
    -webkit-box-pack: center;
    justify-content: center
  }
  .l-header .header__button a:hover {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
    opacity: 1
  }
  .l-header .header__opener {
    display: none
  }
  .hero .hero__title {
    font-size: 6.8rem;
    top: 52.5%;
    margin-top: 0
  }
  .hero .hero__title span {
    font-size: 3.2rem
  }
  .hero .hero__category {
    font-size: 2.8rem;
    max-width: 99.9rem;
    margin: 0 auto
  }
  .hero .hero__text {
    font-size: 1.5rem;
    margin: 0 0 6rem 0;
    text-align: center
  }
  .l-page--top .hero canvas {
    width: 100% !important
  }
  .l-page--about .hero {
    height: 73rem;
    background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/about/main-image01.jpg) no-repeat center bottom;
    background-size: cover
  }
  .l-page--service .hero {
    height: 73rem;
    background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/service/main-image01.jpg) no-repeat center;
    background-size: cover
  }
  .l-page--facility .hero {
    height: 73rem;
    background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/facility/main-image01.jpg) no-repeat center;
    background-size: cover
  }
  .l-page--contact .hero {
    height: 73rem;
    background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/contact/main-image01.jpg) no-repeat center;
    background-size: cover
  }
  .l-page--news .hero {
    height: auto
  }
  .l-page--news .hero__title {
    padding: 20rem 0 6rem 0
  }
  .l-page--news .hero__title span {
    font-size: 5rem
  }
  .l-page--news .hero__title span::after {
    bottom: -1rem;
    height: 10px
  }
  .l-page--download .hero {
    height: auto
  }
  .l-page--download .hero__title {
    padding: 20rem 0 6rem 0
  }
  .l-page--download .hero__title span {
    font-size: 5rem
  }
  .l-page--download .hero__title span::after {
    bottom: -1rem;
    height: 10px
  }
  .border-btn {
    border: 6px solid #d0d0d0
  }
  .border-btn a {
    font-size: 2.4rem
  }
  .border-btn--sm {
    border: 4px solid #d0d0d0
  }
  .border-btn--sm a {
    font-size: 1.3rem
  }
  .btn--primary a {
    font-size: 2.4rem
  }
  .card--image {
    padding-bottom: 8rem
  }
  .card--image .card__textarea {
    padding: 0 3.2rem
  }
  .card--image .card__textarea p {
    font-size: 1.5rem
  }
  .card--image .card__textarea {
    padding-top: 3.5rem
  }
  .card--image .card__textarea--only {
    padding: 0 3.2rem 6rem 3.2rem
  }
  .card--image .border-btn--sm {
    max-width: 28rem;
    margin-top: 2rem;
    margin-right: auto;
    margin-left: auto
  }
  .card-row--image {
    width: 100%;
    margin-right: auto;
    margin-left: auto
  }
  .card-row--image {
    max-width: 100rem;
    margin: 8.5rem auto 0
  }
  .card-row--image .card__image {
    -webkit-box-ordinal-group: 2;
    order: 1
  }
  .card-row--image .card__textarea {
    -webkit-box-ordinal-group: 3;
    order: 2
  }
  .card-row--image .card__btn {
    margin-top: 3rem;
    margin-left: auto;
    -webkit-box-ordinal-group: 4;
    order: 3
  }
  .card-row--image .card__btn--row .border-btn--sm {
    max-width: 28rem;
    margin-right: auto;
    margin-left: auto
  }
  .card-row--image .card__list::after {
    display: block;
    width: 30%;
    content: ''
  }
  .card-row--image .card__list li {
    width: 30%
  }
  .card-row--image > * {
    width: calc((100% - 5.6rem)/ 2)
  }
  .card-row--image .card__textarea {
    padding: 0 3.2rem
  }
  .card-row--image .card__textarea p {
    font-size: 1.5rem
  }
  .card-row--image .card__textarea {
    padding-bottom: 4rem
  }
  .card-row--image .card__textarea h3 {
    font-size: 2.4rem;
    margin: 0 0 4rem
  }
  .card-row--image .card__textarea h3 span {
    padding: 0 0 4rem
  }
  .card-row--image .card__textarea__catch {
    font-size: 1.6rem
  }
  .card-row--image .border-btn--sm {
    max-width: 28rem;
    margin-right: auto;
    margin-left: auto
  }
  .card-row--text {
    max-width: 100rem;
    margin: 2em auto 8rem auto
  }
  .card-row--text .card__textarea {
    padding: 0 3.2rem
  }
  .card-row--text .card__textarea p {
    font-size: 1.5rem
  }
  .card-row--text .card__textarea {
    padding-bottom: 4rem
  }
  .card-row--text .card__textarea h3 {
    font-size: 2.4rem;
    margin: 0 0 4rem
  }
  .card-row--text .card__textarea h3 span {
    padding: 0 0 4rem
  }
  .card-row--text .card__textarea__catch {
    font-size: 1.6rem
  }
  .card-row--text .border-btn--sm {
    max-width: 24rem;
    margin-right: auto;
    margin-left: auto
  }
  .card-row--text .card__list::after {
    display: block;
    width: 30%;
    content: ''
  }
  .card-row--text .card__list li {
    width: 30%
  }
  .flow-list li {
    width: 16rem;
    height: 16rem
  }
  .flow-list li + li {
    margin-left: -2rem
  }
  .flow-list .flow__text {
    height: 3em
  }
  .post-list .post a {
    padding: 2.8rem 3.2rem
  }
  .post-list .post__date {
    font-size: 1.3rem;
    width: 102px
  }
  .post-list .post__category {
    font-size: 1.6rem;
    font-weight: 700;
    width: 124px
  }
  .post-list .post__title {
    font-size: 1.8rem;
    font-weight: 700;
    width: calc(100% - calc(102px + 124px));
    padding-top: 0
  }
  .logo--primary {
    width: 25rem;
    height: 9rem;
    -webkit-box-pack: center;
    justify-content: center
  }
  .logo--primary img {
    -webkit-transform: translate(-1rem, -.2rem);
    transform: translate(-1rem, -.2rem)
  }
  .page__parent__text {
    padding: 8.9rem 0 5rem
  }
  .page__parent__text .text {
    width: 8rem;
    margin: 2rem 0 0;
    padding: 3.5rem 0
  }
  .page__parent__text .title {
    margin: 5rem 0 0
  }
  .page__parent__text .title span {
    min-height: 19.6rem;
    padding: 2rem 1.5rem
  }
  .page__parent__text span {
    font-size: 1.4rem
  }
  .text--caption {
    font-size: 1.4rem
  }
  .section-sub-title, .section-title, .section-title--page, .section-title--secondary, .section-title--thirdry {
    font-size: 6rem
  }
  .section-title span:nth-child(1), .section-title--thirdry span:not(.break):nth-child(1) {
    font-size: 2.8rem
  }
  .has-period {
    text-indent: .5em
  }
  .section-title span:nth-child(2):after {
    height: 1.4rem
  }
  .section-title--secondary {
    font-size: 4.8rem
  }
  .section-title--thirdry span.break {
    display: inline
  }
  .section-title--thirdry span:not(.break):nth-child(2):after {
    height: 1.4rem
  }
  .section-title--page {
    font-size: 5.4rem
  }
  .section-sub-title {
    font-size: 2.8rem;
    margin-top: 6rem
  }
  .section-description {
    margin-top: 6rem;
    text-align: center
  }
  .section-title__label {
    font-size: 2.4rem
  }
  .section-title__label span:after {
    height: 1.4rem
  }
  .section-title__label span:after {
    height: 1rem;
    border-radius: .4rem
  }
  .section-title__label--es {
    margin: 1em 0 4em
  }
  .section-title__label--secondary {
    font-size: 2.8rem;
    margin-bottom: 3rem
  }
  .section-title__label--secondary span {
    font-size: 2rem
  }
  .section-title__subtitle {
    font-size: 2.8rem;
    margin: 1em 0 4em
  }
  .section-textarea p {
    font-size: 1.6rem
  }
  .section-textarea p + p {
    margin-top: 4rem
  }
  .section-lead p {
    font-size: 1.6rem
  }
  .section-lead p + p {
    margin: 8rem 0
  }
  .l-page--about {
    padding-bottom: 5rem
  }
  .l-page--about .section-textarea .sign {
    margin-top: 6rem
  }
  .l-page--about .section-textarea .photo {
    position: absolute;
    top: 0;
    right: 3%;
    width: 100%;
    max-width: 36rem
  }
  .l-page--about .section--philosophy {
    margin-top: 12rem
  }
  .l-page--about .section--philosophy section {
    width: 83.3%;
    margin: 0 auto;
    padding: 7em 0
  }
  .l-page--about .section--philosophy .section-title--secondary {
    font-size: 6rem;
    line-height: 1.4;
    margin-top: 3rem
  }
  .l-page--about .section--philosophy .section-title--thirdry {
    font-size: 3.6rem;
    line-height: 1.66;
    margin-top: 2rem
  }
  .l-page--about .section-colomn {
    display: -webkit-box;
    display: flex;
    margin-top: 4em;
    flex-wrap: wrap;
    justify-content: space-around
  }
  .l-page--about .section-colomn .section-colomn__item {
    width: 26%;
    margin-top: 0
  }
  .l-page--about .section-colomn .section-colomn__item p {
    font-size: 2.4rem
  }
  .l-page--about .section-colomn .section-colomn__item p span {
    font-size: 1.6rem;
    margin-top: 2em;
    white-space: nowrap
  }
  .l-page--about .section--movie {
    width: 100%;
    margin-right: auto;
    margin-left: auto
  }
  .l-page--about .section--movie {
    margin-top: 9rem
  }
  .l-page--about .section--movie .movie__title {
    margin-bottom: 3rem
  }
  .l-page--about .section--movie .movie__player > p {
    font-size: 1.5rem;
    margin-top: 10rem
  }
  .l-page--about .section--movie .movie + .movie {
    margin-top: 6rem
  }
  .l-page--about .section-wrap {
    width: 100%;
    margin-right: auto;
    margin-left: auto
  }
  .l-page--about .section-wrap {
    margin-top: 10rem
  }
  .l-page--about .section-wrap > * {
    width: calc((100% - 5.6rem)/ 2)
  }
  .l-page--about .section__content {
    margin-top: 3.5rem;
    padding: 3.5rem 0 9rem
  }
  .l-page--about .section__content .sub-text {
    margin-left: 12rem
  }
  .l-page--about .section-wrap > :nth-child(1) .section__content {
    line-height: 3
  }
  .l-page--download .section-archive {
    max-width: 1000px;
    margin: auto
  }
  .l-page--download .section-archive ul {
    display: -webkit-box;
    display: flex;
    flex-wrap: wrap;
    -webkit-box-align: baseline;
    align-items: baseline;
    -webkit-box-pack: justify;
    justify-content: space-between
  }
  .l-page--download .section-archive li {
    width: 46%;
    margin-top: 4rem
  }
  .l-page--facility .section-archive {
    max-width: 100rem;
    margin: 0 auto;
    padding: 0 0 10rem
  }
  .l-page--facility .section-archive__head {
    font-size: 2.8rem;
    margin: 0 0 7rem
  }
  .l-page--facility .section-archive__head:before {
    width: 123px;
    height: 10px
  }
  .l-page--facility .section-archive__lead {
    font-size: 1.6rem;
    line-height: 3.6rem;
    margin: 0 0 6rem;
    text-align: center
  }
  .l-page--facility .section-archive__select {
    display: none
  }
  .l-page--facility .section-archive__category {
    display: block;
    margin: 0 0 8rem
  }
  .l-page--facility .section-archive__post {
    display: -webkit-box;
    display: flex;
    padding: 0;
    flex-wrap: wrap
  }
  .l-page--facility .section-archive__item {
    width: 29.6rem;
    margin: 0 5.6rem 5.8rem 0
  }
  .l-page--facility .section-archive__item:nth-child(3n) {
    margin: 0 0 5.8rem
  }
  .l-page--facility .section-hero__thumb {
    height: 68rem
  }
  .l-page--facility .section-hero__title {
    max-width: 82.4rem;
    margin: -8rem auto 0;
    padding: 0 4rem
  }
  .l-page--facility .section-hero__title:before {
    top: 8rem;
    width: 100%;
    height: 12rem;
    border-radius: 6rem 6rem 0 0
  }
  .l-page--facility .section-hero__title span {
    font-size: 3.6rem;
    line-height: 7.2rem
  }
  .l-page--facility .section-news {
    max-width: 82.4rem;
    margin: 0 auto;
    padding: 8rem 0 0
  }
  .l-page--facility .section-news__container {
    padding: 5rem
  }
  .l-page--facility .section-news__head {
    font-size: 2rem
  }
  .l-page--facility .section-news__list li {
    display: -webkit-box;
    display: flex
  }
  .l-page--facility .section-news__list time {
    font-size: 1.3rem;
    margin: 1rem 2rem 0 0
  }
  .l-page--facility .section-news__list a {
    font-size: 1.6rem;
    line-height: 3.6rem
  }
  .l-page--facility .section-news__btn {
    max-width: 30rem;
    margin: 0 auto
  }
  .l-page--facility .section-point {
    max-width: 82.4rem;
    margin: 0 auto;
    padding: 12rem 0 0
  }
  .l-page--facility .section-point__head {
    margin: 0 0 3rem
  }
  .l-page--facility .section-point__lead {
    font-size: 3.2rem;
    line-height: 6.4rem;
    text-align: center
  }
  .l-page--facility .section-gallery {
    padding: 12rem 0 0
  }
  .l-page--facility .section-gallery__head {
    margin: 0 0 5rem
  }
  .l-page--facility .section-gallery__body .swiper-slide span {
    font-size: 2rem
  }
  .l-page--facility .section-gallery__body .swiper-button-next:after, .l-page--facility .section-gallery__body .swiper-button-prev:after {
    font-size: 5rem
  }
  .l-page--facility .section-gallery__body .swiper-button-prev {
    left: 12vw
  }
  .l-page--facility .section-gallery__body .swiper-button-next {
    right: 12vw
  }
  .l-page--facility .section-about {
    display: -webkit-box;
    display: flex;
    max-width: 100rem;
    margin: 0 auto;
    padding: 12rem 0 0;
    -webkit-box-pack: justify;
    justify-content: space-between
  }
  .l-page--facility .section-about__block {
    width: 47rem
  }
  .l-page--facility .section-about__block:last-child {
    padding: 0
  }
  .l-page--facility .section-about__head {
    margin: 0 0 3rem
  }
  .l-page--facility .section-about__btn {
    margin: 5rem 0 0
  }
  .l-page--facility .section-access {
    max-width: 100rem;
    margin: 0 auto;
    padding: 12rem 0 0
  }
  .l-page--facility .section-future {
    max-width: 100rem;
    margin: 0 auto;
    padding: 12rem 0 0
  }
  .l-page--facility .section-future__block {
    display: -webkit-box;
    display: flex;
    margin: 0 0 6rem;
    -webkit-box-align: start;
    align-items: flex-start;
    -webkit-box-pack: justify;
    justify-content: space-between
  }
  .l-page--facility .section-future__thumb {
    width: 47rem
  }
  .l-page--facility .section-future__content {
    width: 47rem
  }
  .l-page--facility .section-future__content h3 {
    font-size: 2.4rem;
    line-height: 4.3rem
  }
  .l-page--facility .button-return {
    max-width: 47rem;
    margin: 0 auto;
    padding: 8rem 0 18rem
  }
  .l-page--contact {
    padding-bottom: 14.5rem
  }
  .l-page--contact .section-textarea {
    width: 100%;
    margin-right: auto;
    margin-left: auto
  }
  .l-page--contact .section-textarea {
    max-width: 82.4rem
  }
  .l-page--contact .form-wrap dl {
    -webkit-box-align: center;
    align-items: center
  }
  .l-page--contact .form-wrap dl + dl {
    margin-top: 3.5rem
  }
  .l-page--contact .form-wrap dt {
    width: 17.6rem
  }
  .l-page--contact .submit-btn {
    margin: 5rem 0 0
  }
  .l-page--info .section-hero {
    padding: 15rem 4rem 0
  }
  .l-page--info .section-hero span:nth-child(1) {
    font-size: 2rem;
    margin: 0 3.2rem 0 0;
    padding: .8rem 4rem;
    border: 4px solid #f39800
  }
  .l-page--info .section-hero span:nth-child(2) {
    font-size: 3.2rem
  }
  .l-page--info .section-info {
    max-width: 82rem;
    margin: 0 auto;
    padding: 12rem 0 0
  }
  .l-page--info .section-info__head {
    font-size: 4rem;
    margin: 0 0 5rem
  }
  .l-page--info .section-info__body dl {
    display: -webkit-box;
    display: flex;
    padding: 2rem 0
  }
  .l-page--info .section-info__body dt {
    line-height: 2.4rem;
    width: 17rem;
    margin: 0
  }
  .l-page--info .section-info__body dd {
    line-height: 3.2rem;
    -webkit-box-flex: 1;
    flex: 1
  }
  .l-page--info .section-faq {
    max-width: 82rem;
    margin: 0 auto;
    padding: 14rem 0 0
  }
  .l-page--info .section-faq__head {
    font-size: 4rem;
    margin: 0 0 5rem
  }
  .l-page--info .section-faq__body dd:before, .l-page--info .section-faq__body dt:before {
    font-size: 3.4rem
  }
  .l-page--info .section-faq__body dt {
    padding: 3rem 7rem
  }
  .l-page--info .section-faq__body dt:before {
    top: 3rem
  }
  .l-page--info .section-faq__body dd {
    font-size: 1.8rem;
    line-height: 3.2rem;
    margin: 1rem 0 0;
    padding: 0 7rem 3rem
  }
  .l-page--info .section-faq__body i {
    top: 3rem
  }
  .l-page--info .section-faq__body li {
    font-size: 1.6rem
  }
  .l-page--info .section-entry {
    padding: 18rem 0
  }
  .l-page--info .section-entry__container {
    width: 82.4rem;
    margin: 0 auto;
    padding: 4rem 8rem
  }
  .l-page--info .section-entry__content {
    width: 105%;
    -webkit-transition: .6s .6s;
    transition: .6s .6s;
    -webkit-transform: translate(-50%, -50%) scale(1.1);
    transform: translate(-50%, -50%) scale(1.1);
    opacity: 0
  }
  .l-page--info .section-entry__content.is-show {
    -webkit-transform: translate(-50%, -50%) scale(1);
    transform: translate(-50%, -50%) scale(1);
    opacity: 1
  }
  .l-page--info .section-entry__head {
    font-size: 6rem
  }
  .l-page--info .section-entry__lead {
    margin: 0 0 3rem;
    text-align: center
  }
  .l-page--info .section-entry__btn {
    display: -webkit-box;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -webkit-box-pack: center;
    justify-content: center
  }
  .l-page--info .section-entry__btn .btn--recruit {
    width: 29.5rem
  }
  .l-page--info .section-entry__btn .btn--recruit:nth-child(1) {
    margin: 0 5.6rem 0 0
  }
  .l-page--news .news-list {
    box-sizing: border-box;
    max-width: 99.9rem;
    margin: 0 auto
  }
  .l-page--news .news-list__item a {
    padding: 4em 5em 4em 0
  }
  .l-page--news .news-list__item a .-date {
    font-size: 1.3rem;
    width: 102px
  }
  .l-page--news .news-list__item a .-category {
    font-size: 1.6rem;
    font-weight: 700;
    width: 124px
  }
  .l-page--news .news-list__item a .-title {
    font-size: 1.8rem;
    font-weight: 700;
    width: calc(100% - 226px);
    padding-top: 0
  }
  .l-page--news .news-pagenation {
    margin: 6rem 0
  }
  .l-page--news .newslist {
    box-sizing: border-box;
    max-width: 99.9rem;
    margin: 0 auto;
    padding: 4rem 8% 4rem 8%;
    border-radius: 62px
  }
  .l-page--news .newslist__item {
    padding: 5rem 0
  }
  .l-page--news .newslist__item .-thumb {
    width: 31.7%
  }
  .l-page--news .newslist__item .-textarea {
    width: 60.4%
  }
  .l-page--news .newsarticle {
    box-sizing: border-box;
    max-width: 99.9rem;
    margin: 0 auto;
    padding: 8rem 8% 8rem 8%;
    border-radius: 62px
  }
  .l-page--news .newsarticle .-ttl {
    font-size: 3rem
  }
  .l-page--news .newsarticle .-thumb {
    width: 78.8%;
    margin: 0 auto
  }
  .l-page--news .newsarticle .newsarticle__body {
    width: 78.8%;
    margin: 0 auto;
    padding-top: 4rem
  }
  .l-page--news .newsarticle .newsarticle__body p {
    font-size: 1.6rem
  }
  .l-page--news .newsnavi {
    max-width: 99.9rem;
    margin: 0 auto;
    padding: 8rem 2rem 0 2rem
  }
  .l-page--news .newsnavi li a {
    font-size: 2rem
  }
  .l-page--news .newsnavi .-prev a:after {
    width: 24px;
    height: 24px
  }
  .l-page--news .newsnavi .-next a:after {
    width: 24px;
    height: 24px
  }
  .l-page--recruit .section-hero {
    height: 80rem
  }
  .l-page--recruit .section-hero__title {
    width: 108.4rem
  }
  .l-page--recruit .section-philosophy {
    max-width: 100rem;
    margin: 0 auto;
    padding: 9rem 0 0
  }
  .l-page--recruit .section-philosophy__illust {
    display: block
  }
  .l-page--recruit .section-philosophy__btn {
    width: 41rem;
    margin: 7rem auto 0
  }
  .l-page--recruit .section-philosophy__btn .border-btn a {
    font-size: 1.8rem
  }
  .l-page--recruit .section-business {
    max-width: 100rem;
    margin: 0 auto;
    padding: 12rem 0 0
  }
  .l-page--recruit .section-business__title {
    font-size: 7rem;
    line-height: 11.2rem;
    margin: 0 0 8rem
  }
  .l-page--recruit .section-business__illust {
    display: block
  }
  .l-page--recruit .section-business__btn {
    width: 41rem;
    margin: 7rem auto 0
  }
  .l-page--recruit .section-business__btn .border-btn a {
    font-size: 1.8rem
  }
  .l-page--recruit .section-topics {
    max-width: 100rem;
    margin: 0 auto;
    padding: 14rem 0 0
  }
  .l-page--recruit .section-topics__content {
    top: 15%;
    width: 105%;
    -webkit-transition: .6s .6s;
    transition: .6s .6s;
    -webkit-transform: translate(-50%, -50%) scale(1.1);
    transform: translate(-50%, -50%) scale(1.1);
    opacity: 0
  }
  .l-page--recruit .section-topics__content.is-show {
    -webkit-transform: translate(-50%, -50%) scale(1);
    transform: translate(-50%, -50%) scale(1);
    opacity: 1
  }
  .l-page--recruit .section-topics__head {
    margin: 0 0 5rem
  }
  .l-page--recruit .section-topics__head span:nth-child(1) {
    font-size: 2.8rem
  }
  .l-page--recruit .section-topics__head span:nth-child(2) {
    font-size: 6rem
  }
  .l-page--recruit .section-topics__lead {
    font-size: 1.8rem;
    margin: 0 0 5rem
  }
  .l-page--recruit .section-topics__list {
    display: -webkit-box;
    display: flex;
    flex-wrap: wrap
  }
  .l-page--recruit .section-topics__item {
    width: 29.6rem;
    margin: 0 5.6rem 5.8rem 0
  }
  .l-page--recruit .section-topics__item:nth-child(3n) {
    margin: 0 0 5.8rem
  }
  .l-page--recruit .section-topics__btn {
    width: 41rem;
    margin: 0 auto
  }
  .l-page--recruit .section-topics__btn .border-btn a {
    font-size: 1.8rem
  }
  .l-page--recruit .section-info {
    max-width: 100rem;
    margin: 0 auto;
    padding: 14rem 0 0
  }
  .l-page--recruit .section-info__content {
    top: 70%;
    width: 105%;
    -webkit-transition: .6s .6s;
    transition: .6s .6s;
    -webkit-transform: translate(-50%, -50%) scale(1.1);
    transform: translate(-50%, -50%) scale(1.1);
    opacity: 0
  }
  .l-page--recruit .section-info__content.is-show {
    -webkit-transform: translate(-50%, -50%) scale(1);
    transform: translate(-50%, -50%) scale(1);
    opacity: 1
  }
  .l-page--recruit .section-info__head {
    margin: 0 0 7.5rem
  }
  .l-page--recruit .section-info__head span:nth-child(1) {
    font-size: 2.8rem
  }
  .l-page--recruit .section-info__head span:nth-child(2) {
    font-size: 6rem
  }
  .l-page--recruit .section-info__lead {
    font-size: 1.8rem;
    margin: 0 0 5rem
  }
  .l-page--recruit .section-info__btn {
    width: 41rem;
    margin: 0 auto
  }
  .l-page--recruit .section-info__btn .border-btn a {
    font-size: 1.8rem
  }
  .l-page--recruit .section-entry {
    padding: 18rem 0
  }
  .l-page--recruit .section-entry__container {
    width: 82.4rem;
    margin: 0 auto;
    padding: 4rem 8rem
  }
  .l-page--recruit .section-entry__content {
    width: 105%;
    -webkit-transition: .6s .6s;
    transition: .6s .6s;
    -webkit-transform: translate(-50%, -50%) scale(1.1);
    transform: translate(-50%, -50%) scale(1.1);
    opacity: 0
  }
  .l-page--recruit .section-entry__content.is-show {
    -webkit-transform: translate(-50%, -50%) scale(1);
    transform: translate(-50%, -50%) scale(1);
    opacity: 1
  }
  .l-page--recruit .section-entry__head {
    font-size: 6rem
  }
  .l-page--recruit .section-entry__lead {
    margin: 0 0 3rem;
    text-align: center
  }
  .l-page--recruit .section-entry__btn {
    display: -webkit-box;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -webkit-box-pack: center;
    justify-content: center
  }
  .l-page--recruit .section-entry__btn .btn--recruit {
    width: 29.5rem
  }
  .l-page--recruit .section-entry__btn .btn--recruit:nth-child(1) {
    margin: 0 5.6rem 0 0
  }
  .l-page--service .card-wrap {
    width: 100%;
    margin-right: auto;
    margin-left: auto
  }
  .l-page--service .card-wrap {
    max-width: 100rem;
    margin: 8.5rem auto 0
  }
  .l-page--service .card-wrap > * {
    width: calc((100% - 5.6rem)/ 2)
  }
  .l-page--top .message-section {
    padding: 20% 0 15.83%
  }
  .l-page--top .message-section p {
    font-size: 1.8rem;
    line-height: 2.6;
    text-align: center
  }
  .l-page--top .section-image {
    margin-top: 4rem
  }
  .l-page--top .btn--primary, .l-page--top .btn--secondary, .l-page--top .btn-list {
    margin-top: 4rem
  }
  .l-page--top .btn--secondary {
    max-width: 24rem
  }
  .l-page--top .l-section--o, .l-page--top .l-section--w {
    margin-top: 24.5rem;
    padding: 6rem 17.4rem 8rem
  }
  .l-page--top .l-section--o .section-title--secondary span:nth-child(1) {
    font-size: 2.8rem
  }
  .l-page--top .l-section--t {
    margin-top: 24.5rem
  }
  .l-page--topics .section-hero {
    padding: 15rem 4rem 0
  }
  .l-page--topics .section-hero span:nth-child(1) {
    font-size: 2rem;
    margin: 0 3.2rem 0 0;
    padding: .8rem 4rem;
    border: 4px solid #f39800
  }
  .l-page--topics .section-hero span:nth-child(2) {
    font-size: 3.2rem
  }
  .l-page--topics .section-info__category select {
    max-width: 34.5rem
  }
  .l-page--topics .section-archive {
    max-width: 100rem;
    margin: 0 auto;
    padding: 11rem 0 0
  }
  .l-page--topics .section-archive__list {
    display: -webkit-box;
    display: flex;
    flex-wrap: wrap
  }
  .l-page--topics .section-archive__item {
    width: 29.6rem;
    margin: 0 5.6rem 5.8rem 0
  }
  .l-page--topics .section-archive__item:nth-child(3n) {
    margin: 0 0 5.8rem
  }
  .l-page--topics .section-entry {
    padding: 18rem 0
  }
  .l-page--topics .section-entry__container {
    width: 82.4rem;
    margin: 0 auto;
    padding: 4rem 8rem
  }
  .l-page--topics .section-entry__content {
    width: 105%;
    -webkit-transition: .6s .6s;
    transition: .6s .6s;
    -webkit-transform: translate(-50%, -50%) scale(1.1);
    transform: translate(-50%, -50%) scale(1.1);
    opacity: 0
  }
  .l-page--topics .section-entry__content.is-show {
    -webkit-transform: translate(-50%, -50%) scale(1);
    transform: translate(-50%, -50%) scale(1);
    opacity: 1
  }
  .l-page--topics .section-entry__head {
    font-size: 6rem
  }
  .l-page--topics .section-entry__lead {
    margin: 0 0 3rem;
    text-align: center
  }
  .l-page--topics .section-entry__btn {
    display: -webkit-box;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -webkit-box-pack: center;
    justify-content: center
  }
  .l-page--topics .section-entry__btn .btn--recruit {
    width: 29.5rem
  }
  .l-page--topics .section-entry__btn .btn--recruit:nth-child(1) {
    margin: 0 5.6rem 0 0
  }
  .l-page--topics .section-single {
    padding: 7rem 0 10rem
  }
  .l-page--topics .section-single__thumb {
    max-width: 84.5rem;
    margin: 0 auto
  }
  .l-page--topics .section-single__content {
    max-width: 65rem;
    margin: 0 auto
  }
  .l-page--topics .section-single__content h1, .l-page--topics .section-single__content h2, .l-page--topics .section-single__content h3, .l-page--topics .section-single__content h4, .l-page--topics .section-single__content h5, .l-page--topics .section-single__content h6, .l-page--topics .section-single__content ol, .l-page--topics .section-single__content p, .l-page--topics .section-single__content ul {
    margin: 5rem 0
  }
  .l-page--topics .section-single__content h1 {
    font-size: 4.6rem
  }
  .l-page--topics .section-single__content h2, .l-page--topics .section-single__content h3, .l-page--topics .section-single__content h4, .l-page--topics .section-single__content h5, .l-page--topics .section-single__content h6 {
    font-size: 2.6rem
  }
  .l-page--topics .section-single__pager {
    max-width: 65rem;
    margin: 0 auto
  }
  .l-page--topics .section-single__pager a {
    font-size: 1.8rem
  }
  .l-page--topics .section-relation {
    max-width: 100rem;
    margin: 0 auto;
    padding: 0
  }
  .l-page--topics .section-relation__container {
    padding: 10rem 0 0
  }
  .l-page--topics .section-relation__head {
    font-size: 2.6rem
  }
  .l-page--topics .section-relation__list {
    display: -webkit-box;
    display: flex;
    flex-wrap: wrap
  }
  .l-page--topics .section-relation__item {
    width: 29.6rem;
    margin: 0 5.6rem 5.8rem 0
  }
  .l-page--topics .section-relation__item:nth-child(3n) {
    margin: 0 0 5.8rem
  }
  .l-page--topics .section-relation__btn {
    max-width: 41rem;
    margin: 0 auto
  }
  .l-page--topics .news-pagenation {
    margin: 6rem 0
  }
}
@media print, screen and (min-width:1130px) {
  .l-header .header__logo {
    max-width: 14.2rem
  }
  .l-header .header__nav a {
    font-size: 1.6rem
  }
}
@media print, screen and (min-width:1200px) {
  .l-content {
    width: 100%
  }
  .l-section--o, .l-section--w {
    width: 100%
  }
  .l-section--t {
    width: 100%
  }
}
@media only screen and (orientation:landscape) and (max-width:812px) {
  .l-page--top .page__movie video {
    max-width: 100%;
    max-height: none
  }
}
@media only screen and (max-width:767px) {
  html {
    font-size: calc(100vw / 37.5)
  }
  body {
    overflow: hidden
  }
  .is-pc {
    display: none
  }
  .c-overlay.is-active {
    background: rgba(0, 0, 0, .5) !important
  }
  .l-page--about .section-lead, .l-page--about .section-textarea, .l-page--service .section-lead, .l-page--service .section-textarea {
    padding: 0 2rem
  }
  .l-footer .footer__inner {
    padding: 0 2rem
  }
  .l-footer .footer__bg {
    bottom: 5rem;
    height: 25rem;
    background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/top/icon-top01.png) no-repeat center bottom;
    background-size: 110% auto
  }
  .l-footer .aside__row {
    flex-direction: column;
    margin-top: 3rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal
  }
  .l-footer .aside__row section:last-child {
    margin-top: 4rem;
    padding-top: 4rem
  }
  .l-header.l-header--top {
    background: #f3f6ef
  }
  .l-header.l-header--page {
    position: absolute;
    z-index: 40;
    top: 0;
    left: 0;
    width: 100%
  }
  .l-header .header__logo {
    max-width: 8.8rem
  }
  .l-header .header__nav {
    position: fixed;
    z-index: 40;
    top: 0;
    left: 0;
    overflow-y: scroll;
    width: 100%;
    height: 100vh;
    padding: 100px 0;
    -webkit-transition: .3s;
    transition: .3s;
    -webkit-transform: translateX(100%);
    transform: translateX(100%);
    text-align: center;
    background: #fff
  }
  .l-header .header__nav ul {
    flex-direction: column;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal
  }
  .l-header .header__nav li {
    margin-bottom: 3rem
  }
  .l-header .header__nav a.is-current:after {
    display: none
  }
  .l-header .header__drawer > a {
    padding: 0 3rem 0 0
  }
  .l-header .header__drawer > a:before {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    box-sizing: border-box;
    width: 8px;
    height: 8px;
    margin: auto;
    content: '';
    -webkit-transition: .3s;
    transition: .3s;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    border-right: 2px solid #7d7d7d;
    border-bottom: 2px solid #7d7d7d
  }
  .l-header .header__drawer > a.active:before {
    -webkit-transform: rotate(225deg);
    transform: rotate(225deg)
  }
  .l-header .header__drawer ul {
    display: none;
    width: 60%;
    margin: 2rem auto 0
  }
  .l-header .header__button {
    margin: 3rem 0 0
  }
  .l-header .header__button a {
    display: block;
    width: 70%;
    margin: auto;
    padding: 1rem;
    color: #fff;
    border-radius: 50px;
    background: #f39800
  }
  .l-header.is-active .header__nav {
    -webkit-transform: translateX(0);
    transform: translateX(0)
  }
  .l-page--top .page__movie video {
    max-height: 100vh
  }
  .l-page--top .hero {
    margin: -.1rem 0
  }
  .l-page--top .hero .hero__animation {
    display: -webkit-box;
    display: flex;
    -webkit-box-pack: center;
    justify-content: center
  }
  .l-page--about .hero {
    height: 28rem;
    background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/about/main-image01.jpg) no-repeat center bottom;
    background-size: auto 28rem
  }
  .l-page--service .hero {
    height: 28rem;
    background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/service/main-image01.jpg) no-repeat center;
    background-size: auto 28rem
  }
  .l-page--facility .hero {
    height: 28rem;
    background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/facility/main-image01.jpg) no-repeat center;
    background-size: auto 28rem
  }
  .l-page--contact .hero {
    height: 28rem;
    background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/contact/main-image01.jpg) no-repeat center;
    background-size: auto 28rem
  }
  .l-page--news .hero {
    height: auto
  }
  .l-page--download .hero {
    height: auto
  }
  .post-list .post a i {
    right: .5rem
  }
  .card--image {
    display: -webkit-box;
    display: flex;
    flex-direction: column;
    margin-top: 6rem;
    padding: 0 2rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal
  }
  .card--image:first-of-type {
    margin-top: 2rem
  }
  .card--image .card__title {
    -webkit-box-ordinal-group: 2;
    order: 1
  }
  .card--image .card__textarea {
    -webkit-box-ordinal-group: 3;
    order: 2
  }
  .card--image .card__image {
    padding: 0 3rem;
    -webkit-box-ordinal-group: 4;
    order: 3
  }
  .card--image .card__textarea {
    padding-bottom: 3rem
  }
  .card--image .card__textarea--only {
    padding-bottom: 4rem
  }
  .card--image .card__btn {
    margin-top: 2rem;
    -webkit-box-ordinal-group: 5;
    order: 4
  }
  .card-row--image {
    flex-direction: column;
    margin-top: 6rem;
    padding: 0 2rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal
  }
  .card-row--image .card__image {
    padding: 0 3rem
  }
  .card-row--image .card__btn {
    margin-top: 3rem
  }
  .card-row--text {
    margin-top: 6rem;
    padding: 0 2rem
  }
  .icon-wrap--face {
    display: none
  }
  .flow-list .flow__num {
    -webkit-transform: translateY(-1rem) scale(.4);
    transform: translateY(-1rem) scale(.4);
    -webkit-transform-origin: bottom;
    transform-origin: bottom
  }
  .flow-list .flow__text {
    width: 10rem;
    height: 2rem;
    -webkit-transform: translateY(-1rem) scale(.4);
    transform: translateY(-1rem) scale(.4);
    -webkit-transform-origin: top;
    transform-origin: top
  }
  .post-list .post a {
    flex-wrap: wrap
  }
  .logo--primary {
    padding: 0 0 0 1.5rem
  }
  .logo--primary img {
    width: 12rem
  }
  .section-description {
    padding: 0 1rem
  }
  .l-page--about .section-textarea p br {
    display: none
  }
  .l-page--about .section-textarea .sign {
    width: 17rem;
    margin-top: 2rem;
    margin-left: auto
  }
  .l-page--about .section-textarea .photo {
    margin-top: 4rem
  }
  .l-page--about .section--philosophy {
    margin-top: 7rem;
    padding: 0 2rem
  }
  .l-page--about .section--philosophy .section-title--secondary {
    font-size: 2.6rem;
    margin-top: 1rem
  }
  .l-page--about .section--philosophy .section-title--thirdry {
    font-size: 2.6rem;
    margin-top: 1rem
  }
  .l-page--about .section--movie {
    padding: 0 2rem
  }
  .l-page--about .section-wrap {
    flex-direction: column;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal
  }
  .l-page--about .section__content {
    margin: 3.5rem 2rem 0;
    padding: 3.5rem 0
  }
  .l-page--about .section__content dl {
    flex-direction: column;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal
  }
  .l-page--about .section__content dl + dl {
    margin-top: 1rem
  }
  .l-page--about .section__content dd, .l-page--about .section__content dt {
    line-height: 2
  }
  .l-page--about .section__content .sub-text {
    margin: 1rem 0
  }
  .l-page--about .section__content .break {
    display: block
  }
  .l-page--contact .section-textarea {
    padding: 0 4rem
  }
  .l-page--contact .form-wrap dl {
    flex-direction: column;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal
  }
  .l-page--contact .form-wrap dd {
    margin-top: 1.5rem
  }
  .l-page--news .newslist__item .-thumb {
    padding-bottom: 2rem
  }
  .l-page--news .newsarticle .-ttl br {
    display: none
  }
  .l-page--service .card-wrap {
    padding-bottom: 6rem
  }
  .l-page--top .message-section:after, .l-page--top .message-section:before {
    position: absolute;
    left: 50%;
    width: 100%;
    content: '';
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%)
  }
  .l-page--top .message-section:before {
    top: -11.5rem;
    height: 20rem;
    background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/top/icon-top01.png) no-repeat top center;
    background-size: 115%
  }
  .l-page--top .message-section:after {
    bottom: -5rem;
    height: 17rem;
    background: url(https://www.ittokai.or.jp/wp/wp-content/themes/ittokai/assets/img/top/icon-bottom01.png) no-repeat bottom center;
    background-size: 115%
  }
  .l-page--top .l-section--o, .l-page--top .l-section--w {
    width: calc(100% - 4rem);
    margin-right: auto;
    margin-left: auto
  }
  .l-page--top .l-section--t {
    padding: 0 1rem
  }
  .l-page--top .post-list {
    padding: 0 1rem
  }
}
@-webkit-keyframes fuwafuwa {
  0% {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0)
  }
  50% {
    -webkit-transform: translate3d(0, 1rem, 0);
    transform: translate3d(0, 1rem, 0)
  }
  100% {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0)
  }
}
@keyframes fuwafuwa {
  0% {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0)
  }
  50% {
    -webkit-transform: translate3d(0, 1rem, 0);
    transform: translate3d(0, 1rem, 0)
  }
  100% {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0)
  }
}
/* 
*
* banner追加 style 240528
*
*/
.banner-contact {
  position: fixed;
  z-index: 2;
  right: 0;
  bottom: 20px;
  display: -webkit-box;
  display: flex;
  flex-direction: column;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  gap: 6px 0
}
.banner-contact .banner-contact__item {
  width: 238px
}
.banner-contact .banner-contact__item:nth-child(1) a {
  background-color: #f39800
}
.banner-contact .banner-contact__item:nth-child(2) a {
  background-color: #00b900
}
.banner-contact .banner-contact__item a {
  display: -webkit-box;
  display: flex;
  box-sizing: border-box;
  padding: 14px 14px 14px 26px;
  color: #fff;
  border: 3px solid #fff;
  border-right: none;
  border-radius: 200px 0 0 200px;
  -webkit-box-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  align-items: center
}
.banner-contact .banner-contact__item p {
  font-size: 13px;
  font-weight: 700;
  line-height: 1.6;
  -webkit-box-flex: 1;
  flex: 1
}
.banner-contact .banner-contact__item img {
  display: none
}
@media print, screen and (min-width:768px) {
  .banner-contact {
    bottom: 30px;
    gap: 12px 0
  }
  .banner-contact .banner-contact__item {
    width: 403px
  }
  .banner-contact .banner-contact__item a {
    padding: 17px 14px 17px 28px;
    border: 4px solid #fff;
    border-right: none
  }
  .banner-contact .banner-contact__item p {
    font-size: 1.8rem;
    line-height: 1.42
  }
  .banner-contact .banner-contact__item img {
    display: block;
    width: 60px
  }
}
/* 
*
* movies(動画一覧)追加 style 250826
*
*/
.l-page--movies {
  --primary-c: #f39800;
  width: min(90%, 100rem);
  margin-inline: auto;
  padding-bottom: 10rem;
  .categories-nav, .tags-nav {
    margin-bottom: 5rem;
    h2 {
      font-size: 1.6rem;
      display: flex;
      align-items: center;
      gap: 0.8rem;
      margin-bottom: 1em;
      &::before {
        content: "";
        width: 1rem;
        aspect-ratio: 1;
        background-color: currentColor;
      }
    }
  }
  .categories-nav {
    font-size: clamp(1.3rem, 1.3vw, 20px);
    ul {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(14em, 1fr));
      gap: 1em max(1vw, 1rem);
      a {
        border: 1px solid var(--primary-c);
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 1.2rem;
        padding: 0.6em 1em;
        transition-property: border-radius, color;
		  font-size: 1.3rem;
        &:not(:is(.is-current *)):hover {
          opacity: 1;
          border-radius: 0.6em;
          color: var(--primary-c);
        }
        &:after {
          content: "";
          rotate: 45deg;
          width: 0.8rem;
          aspect-ratio: 1;
          border-top: 1px solid;
          border-right: 1px solid;
        }
      }
      .is-current a {
        color: #fff;
        background-color: var(--primary-c);
        &:hover {
          opacity: 1;
        }
      }
    }
  }
  .tags-nav {
    font-size: clamp(1.1rem, 1.1vw, 16px);
    ul {
      display: flex;
      flex-wrap: wrap;
      gap: 1rem;
      a {
        background-color: #eee;
        color: #666;
        font-weight: 500;
        padding: 0.6em 1em;
        border-radius: 2em;
        display: inline-block;
      }
      .is-current a {
        color: #fff;
        background-color: #666;
        &:hover {
          opacity: 1;
        }
      }
    }
  }
  button {
    padding: 0;
    border: none;
    outline: none;
    background: none;
    cursor: pointer;
  }
  .category-archive {
    h2 {
      font-size: clamp(1.8rem, 2vw, 24px);
      border-bottom: 1px solid;
      padding-bottom: .3em;
      margin-bottom: 2em;
    }
    ul {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
      gap: max(3vw, 3rem) max(3%, 1rem);
    }
    figure {
      display: flex;
      flex-direction: column;
      gap: 6px;
      > div {
        position: relative;
        overflow: hidden;
        border-radius: 10px;
      }
    }
    figcaption {
      font-size: 1.6rem;
      line-height: 1.7;
    }
    .play-icon {
      width: 16%;
      position: absolute;
      z-index: 2;
      inset: 0;
      margin: auto;
      pointer-events: none;
    }
    button {
      width: 100%;
      img {
        width: 100%;
        height: auto;
        aspect-ratio: 16/9;
        object-fit: cover;
        filter: brightness(0.6);
        transition-property: filter, scale;
        transition-duration: 0.3s;
      }
      &:hover {
        img {
          filter: brightness(1);
          scale: 1.07;
        }
      }
    }
    ~ .category-archive {
      margin-top: max(3vw, 3rem);
    }
  }
  .modal {
    position: fixed;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.7);
    z-index: 200;
    display: grid;
    place-items: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s;
    .inner {
      width: min(90%, 900px);
      position: relative;
      display: flex;
      flex-direction: column;
      gap: 1em;
      button {
        align-self: end;
        img {
          width: 30px;
        }
      }
    }
    &.open {
      opacity: 1;
      pointer-events: auto;
    }
    iframe {
      width: 100%;
      height: auto;
      aspect-ratio: 16/9;
      object-fit: cover;
    }
  }
  .movie-tag {
    display: block;
    width: fit-content;
    font-size: 1.3rem;
    padding: .3em .6em;
    background-color: #eee;
    color: #666;
    border-radius: 2em;
    margin-top: 6px;
  }
  .more {
    display: block;
    width: fit-content;
    margin: 1.6rem 0 0 auto;
    font-size: 1.6rem;
    padding: 1rem 2rem;
    border: 3px solid #d2d2d2;
    border-radius: 2em;
    color: #7d7d7d;
    font-weight: 600;
  }
}
@media (width < 1320px) {
  .l-page--movies .categories-nav {
    ul {
      grid-template-columns: repeat(auto-fill, minmax(16em, 1fr));
      a {
        gap: .6rem;
        padding-inline: .5rem;
        &:after {
          width: 0.5rem;
        }
      }
    }
  }
}
@media (width < 1200px) {
  .l-header .header__nav a {
    font-size: 1.4rem;
  }
  .l-page--movies .categories-nav {
    ul {
      grid-template-columns: repeat(auto-fill, minmax(19em, 1fr));
      a {
        gap: .6rem;
        padding-inline: .5rem;
        &:after {
          width: 0.5rem;
        }
      }
    }
  }
}
@media (width < 1074px) {
  .l-header {
    min-width: 98%;
  }
}
@media (width < 768px) {
  .l-page--movies .categories-nav {
    ul {
      grid-template-columns: repeat(auto-fill, minmax(12em, 1fr));
      a {
        gap: .6rem;
        padding-inline: .5rem;
        &:after {
          width: 0.5rem;
        }
      }
    }
  }
}