@charset "UTF-8";
/*!
Theme Name: edutainment-lab-theme
Author: Edutainment-Lab
Author URI: https://edutainment-lab.com/
Description: Edutainment Lab website theme
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: edutainment-lab-theme
Tags: custom-logo, custom-menu
*/

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
}

main {
  display: block;
}

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

hr {
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  height: 0;
  overflow: visible;
}

pre {
  font-family: monospace, monospace;
  font-size: 1em;
}

a {
  background-color: transparent;
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

b,
strong {
  font-weight: bolder;
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

small {
  font-size: 80%;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

img {
  border-style: none;
}

button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

fieldset {
  padding: 0.35em 0.75em 0.625em;
}

legend {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type=checkbox],
[type=radio] {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 0;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

details {
  display: block;
}

summary {
  display: list-item;
}

template {
  display: none;
}

[hidden] {
  display: none;
}

*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

body,
button,
input,
select,
optgroup,
textarea {
  color: #1c1c1c;
  font-family: "Roboto", "Noto Sans JP", "ヒラギノ角ゴシック", "Hiragino Sans", "メイリオ", Meiryo, sans-serif;
  line-height: 1.8;
}

p {
  margin: 0;
}

dfn,
i {
  font-style: italic;
}

cite,
em {
  font-style: normal;
}

blockquote {
  margin: 0 1.5em;
}

address {
  margin: 0 0 1.5em;
}

pre {
  background: #cecece;
  font-family: Courier, monospace;
  line-height: 1.5;
  margin-bottom: 1.5em;
  max-width: 100%;
  overflow: auto;
  padding: 1.5em;
}

code,
kbd,
tt,
var {
  font-family: Monaco, Consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
}

abbr,
acronym {
  border-bottom: 1px dotted #cecece;
  cursor: help;
}

mark,
ins {
  background: #fff9c0;
  text-decoration: none;
}

big {
  font-size: 125%;
}

html {
  height: 100%;
  overflow-x: hidden;
  overscroll-behavior-y: none;
  scroll-behavior: smooth;
  width: 100%;
  scroll-padding-top: 42px;
}

body {
  background-color: #f5f5f5;
  font-size: clamp(0.875rem, 0.818rem + 0.25vw, 1rem);
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  margin: 0;
  overscroll-behavior-y: none;
  padding: 0;
  width: 100%;
  overflow-x: hidden;
}

hr {
  background-color: #cecece;
  border: 0;
  height: 1px;
  margin: 40px 0;
}

ul,
ol {
  margin: 1em 0;
  padding: 0 0 0 1.5em;
}

ul {
  list-style: disc;
}

ol {
  list-style: decimal;
}

li > ul,
li > ol {
  margin: 0 0 0 1em;
}

dt {
  font-weight: 700;
}

dd {
  margin: 0;
}

embed,
iframe,
object {
  max-width: 100%;
}

img {
  height: auto;
  max-width: 100%;
  vertical-align: bottom;
}

figure {
  margin: 1em 0;
}

figcaption {
  font-size: clamp(0.75rem, 0.693rem + 0.25vw, 0.875rem);
}

table {
  border-collapse: collapse;
  width: 100%;
}

th,
td {
  border: 1px solid #cecece;
  padding: 0.5rem 1rem;
}

th {
  font-weight: 700;
  vertical-align: middle;
}

a {
  color: #00a3ff;
  text-decoration: underline;
  text-decoration-color: transparent;
  -webkit-transition: text-decoration-color 0.2s ease-in-out;
  transition: text-decoration-color 0.2s ease-in-out;
}
a:focus, a:active {
  text-decoration-color: #00a3ff;
}
a:focus {
  outline: thin dotted;
}
a:active {
  outline: 0;
}

button,
input[type=button],
input[type=reset],
input[type=submit] {
  border: 1px solid #ddd;
  border-radius: 8px;
  background-color: #e9e9e9;
  color: #1c1c1c;
  line-height: 1;
  padding: 0.5rem 1rem;
  -webkit-transition: background-color 0.2s ease-in-out, border 0.2s ease-in-out;
  transition: background-color 0.2s ease-in-out, border 0.2s ease-in-out;
}
button:active, button:focus,
input[type=button]:active,
input[type=button]:focus,
input[type=reset]:active,
input[type=reset]:focus,
input[type=submit]:active,
input[type=submit]:focus {
  border-color: #bbb;
}

input[type=text],
input[type=email],
input[type=url],
input[type=password],
input[type=search],
input[type=number],
input[type=tel],
input[type=range],
input[type=date],
input[type=month],
input[type=week],
input[type=time],
input[type=datetime],
input[type=datetime-local],
input[type=color],
textarea {
  background-color: #fff;
  color: #1c1c1c;
  border: 1px solid #ddd;
  border-radius: 4px;
  padding: 0.5rem;
}
input[type=text]:focus,
input[type=email]:focus,
input[type=url]:focus,
input[type=password]:focus,
input[type=search]:focus,
input[type=number]:focus,
input[type=tel]:focus,
input[type=range]:focus,
input[type=date]:focus,
input[type=month]:focus,
input[type=week]:focus,
input[type=time]:focus,
input[type=datetime]:focus,
input[type=datetime-local]:focus,
input[type=color]:focus,
textarea:focus {
  color: #bbb;
}
input[type=text]::-webkit-input-placeholder, input[type=email]::-webkit-input-placeholder, input[type=url]::-webkit-input-placeholder, input[type=password]::-webkit-input-placeholder, input[type=search]::-webkit-input-placeholder, input[type=number]::-webkit-input-placeholder, input[type=tel]::-webkit-input-placeholder, input[type=range]::-webkit-input-placeholder, input[type=date]::-webkit-input-placeholder, input[type=month]::-webkit-input-placeholder, input[type=week]::-webkit-input-placeholder, input[type=time]::-webkit-input-placeholder, input[type=datetime]::-webkit-input-placeholder, input[type=datetime-local]::-webkit-input-placeholder, input[type=color]::-webkit-input-placeholder, textarea::-webkit-input-placeholder {
  color: #cecece;
}
input[type=text]::-moz-placeholder, input[type=email]::-moz-placeholder, input[type=url]::-moz-placeholder, input[type=password]::-moz-placeholder, input[type=search]::-moz-placeholder, input[type=number]::-moz-placeholder, input[type=tel]::-moz-placeholder, input[type=range]::-moz-placeholder, input[type=date]::-moz-placeholder, input[type=month]::-moz-placeholder, input[type=week]::-moz-placeholder, input[type=time]::-moz-placeholder, input[type=datetime]::-moz-placeholder, input[type=datetime-local]::-moz-placeholder, input[type=color]::-moz-placeholder, textarea::-moz-placeholder {
  color: #cecece;
}
input[type=text]:-ms-input-placeholder, input[type=email]:-ms-input-placeholder, input[type=url]:-ms-input-placeholder, input[type=password]:-ms-input-placeholder, input[type=search]:-ms-input-placeholder, input[type=number]:-ms-input-placeholder, input[type=tel]:-ms-input-placeholder, input[type=range]:-ms-input-placeholder, input[type=date]:-ms-input-placeholder, input[type=month]:-ms-input-placeholder, input[type=week]:-ms-input-placeholder, input[type=time]:-ms-input-placeholder, input[type=datetime]:-ms-input-placeholder, input[type=datetime-local]:-ms-input-placeholder, input[type=color]:-ms-input-placeholder, textarea:-ms-input-placeholder {
  color: #cecece;
}
input[type=text]::-ms-input-placeholder, input[type=email]::-ms-input-placeholder, input[type=url]::-ms-input-placeholder, input[type=password]::-ms-input-placeholder, input[type=search]::-ms-input-placeholder, input[type=number]::-ms-input-placeholder, input[type=tel]::-ms-input-placeholder, input[type=range]::-ms-input-placeholder, input[type=date]::-ms-input-placeholder, input[type=month]::-ms-input-placeholder, input[type=week]::-ms-input-placeholder, input[type=time]::-ms-input-placeholder, input[type=datetime]::-ms-input-placeholder, input[type=datetime-local]::-ms-input-placeholder, input[type=color]::-ms-input-placeholder, textarea::-ms-input-placeholder {
  color: #cecece;
}
input[type=text]::placeholder,
input[type=email]::placeholder,
input[type=url]::placeholder,
input[type=password]::placeholder,
input[type=search]::placeholder,
input[type=number]::placeholder,
input[type=tel]::placeholder,
input[type=range]::placeholder,
input[type=date]::placeholder,
input[type=month]::placeholder,
input[type=week]::placeholder,
input[type=time]::placeholder,
input[type=datetime]::placeholder,
input[type=datetime-local]::placeholder,
input[type=color]::placeholder,
textarea::placeholder {
  color: #cecece;
}

select {
  border: 1px solid #ddd;
}

textarea {
  width: 100%;
}

.global-header {
  background-color: #fff;
  -webkit-box-shadow: 0px 2px 10px 0px rgba(0, 0, 0, 0.15);
          box-shadow: 0px 2px 10px 0px rgba(0, 0, 0, 0.15);
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
}
.global-header .global-header-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 auto;
  position: relative;
  width: 100%;
}

.header-logo {
  line-height: 1;
  margin: 0 0 0 20px;
  width: 140px;
}
.header-logo .custom-logo-link {
  display: inline-block;
  line-height: 1;
}

.header-logo {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}

.menu-button-block {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}

.global-menu-block {
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
}

.navi-backdrop {
  display: none;
}
.navi-backdrop.backdrop-active {
  background-color: rgba(28, 28, 28, 0.7);
  display: block;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 99;
}

.footer-primary {
  background-color: #f5f5f5;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 40px;
  padding: 40px;
}

.footer-logo {
  width: 240px;
}

.footer-primary-navigation .primary-navi a {
  display: block;
  font-size: 18px;
}

.footer-secondary {
  background-color: #1c1c1c;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 40px;
  padding: 24px 40px;
}
.footer-secondary .secondary-navi {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 16px;
}
.footer-secondary .secondary-navi a {
  color: #fff;
}
.footer-secondary .secondary-navi a::after {
  background-color: #fff;
}

.copyright_txt {
  color: #fff;
  font-family: "Roboto Condensed", sans-serif;
  font-size: clamp(0.75rem, 0.693rem + 0.25vw, 0.875rem);
}

.page-top {
  background-color: #fff;
  border-bottom: 1px solid #e9e9e9;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  padding: 16px 20px;
  width: 100%;
}
.page-top .page-top-inner {
  min-width: 115px;
}
.page-top .page-top-link {
  color: #1c1c1c;
  display: block;
  font-family: "Roboto Condensed", sans-serif;
  text-decoration: underline;
  text-decoration-color: transparent;
  -webkit-transition: text-decoration-color 0.2s ease-in-out;
  transition: text-decoration-color 0.2s ease-in-out;
}
.page-top .page-top-link .page-top-text {
  padding: 0 48px 0 0;
  position: relative;
}
.page-top .page-top-link .page-top-text::after {
  background-color: #1c1c1c;
  border-radius: 50%;
  content: "↑";
  color: #fff;
  display: block;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 400;
  height: 32px;
  line-height: 1;
  padding: 7px 0 0 0;
  position: absolute;
  top: 45%;
  right: -16px;
  text-align: center;
  -webkit-transform: translate(-50%, -50%) scale(100%);
          transform: translate(-50%, -50%) scale(100%);
  -webkit-transition: -webkit-transform 0.2s ease-in-out;
  transition: -webkit-transform 0.2s ease-in-out;
  transition: transform 0.2s ease-in-out;
  transition: transform 0.2s ease-in-out, -webkit-transform 0.2s ease-in-out;
  width: 32px;
}

.main-contents {
  padding: 42px 0 0;
}

.primary-navi {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 32px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.primary-navi a {
  background-image: -webkit-gradient(linear, left top, left bottom, from(#00a3ff), to(#00a3ff));
  background-image: linear-gradient(#00a3ff, #00a3ff);
  background-size: 0 2px;
  background-position: bottom right;
  background-repeat: no-repeat;
  color: #1c1c1c;
  font-family: "Roboto Condensed", sans-serif;
  font-weight: 700;
  padding: 0 0 4px;
  text-decoration: none;
  -webkit-transition: background-size 0.2s ease-in-out;
  transition: background-size 0.2s ease-in-out;
}

.secondary-navi {
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: 12px;
}
.secondary-navi a {
  padding: 0 20px 0 0;
  position: relative;
}
.secondary-navi a::after {
  background-repeat: no-repeat;
  content: "";
  display: block;
  height: 12px;
  -webkit-mask-image: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjQiIGhlaWdodD0iMjQiIHZpZXdCb3g9IjAgMCAyNCAyNCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48ZyBjbGlwLXBhdGg9InVybCgjY2xpcDBfMzFfOTEpIj48cGF0aCBkPSJNMjIgMEgxNy44M0MxNy4yOCAwIDE2LjgzIDAuNDUgMTYuODMgMUMxNi44MyAxLjU1IDE3LjI4IDIgMTcuODMgMkgyMC4zOUwxMS4xOSAxMS4yQzEwLjggMTEuNTkgMTAuOCAxMi4yMiAxMS4xOSAxMi42MUMxMS4zOSAxMi44MSAxMS42NCAxMi45IDExLjkgMTIuOUMxMi4xNiAxMi45IDEyLjQxIDEyLjggMTIuNjEgMTIuNjFMMjIgMy4yMlY2LjE3QzIyIDYuNzIgMjIuNDUgNy4xNyAyMyA3LjE3QzIzLjU1IDcuMTcgMjQgNi43MiAyNCA2LjE3VjJDMjQgMC45IDIzLjEgMCAyMiAwWiIgZmlsbD0iYmxhY2siLz48cGF0aCBkPSJNMjMgMTJDMjIuNDUgMTIgMjIgMTIuNDUgMjIgMTNWMjJIMlYySDExQzExLjU1IDIgMTIgMS41NSAxMiAxQzEyIDAuNDUgMTEuNTUgMCAxMSAwSDJDMC45IDAgMCAwLjkgMCAyVjIyQzAgMjMuMSAwLjkgMjQgMiAyNEgyMkMyMy4xIDI0IDI0IDIzLjEgMjQgMjJWMTNDMjQgMTIuNDUgMjMuNTUgMTIgMjMgMTJaIiBmaWxsPSJibGFjayIvPjwvZz48ZGVmcz48Y2xpcFBhdGggaWQ9ImNsaXAwXzMxXzkxIj48cmVjdCB3aWR0aD0iMjQiIGhlaWdodD0iMjQiIGZpbGw9IndoaXRlIi8+PC9jbGlwUGF0aD48L2RlZnM+PC9zdmc+");
          mask-image: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjQiIGhlaWdodD0iMjQiIHZpZXdCb3g9IjAgMCAyNCAyNCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48ZyBjbGlwLXBhdGg9InVybCgjY2xpcDBfMzFfOTEpIj48cGF0aCBkPSJNMjIgMEgxNy44M0MxNy4yOCAwIDE2LjgzIDAuNDUgMTYuODMgMUMxNi44MyAxLjU1IDE3LjI4IDIgMTcuODMgMkgyMC4zOUwxMS4xOSAxMS4yQzEwLjggMTEuNTkgMTAuOCAxMi4yMiAxMS4xOSAxMi42MUMxMS4zOSAxMi44MSAxMS42NCAxMi45IDExLjkgMTIuOUMxMi4xNiAxMi45IDEyLjQxIDEyLjggMTIuNjEgMTIuNjFMMjIgMy4yMlY2LjE3QzIyIDYuNzIgMjIuNDUgNy4xNyAyMyA3LjE3QzIzLjU1IDcuMTcgMjQgNi43MiAyNCA2LjE3VjJDMjQgMC45IDIzLjEgMCAyMiAwWiIgZmlsbD0iYmxhY2siLz48cGF0aCBkPSJNMjMgMTJDMjIuNDUgMTIgMjIgMTIuNDUgMjIgMTNWMjJIMlYySDExQzExLjU1IDIgMTIgMS41NSAxMiAxQzEyIDAuNDUgMTEuNTUgMCAxMSAwSDJDMC45IDAgMCAwLjkgMCAyVjIyQzAgMjMuMSAwLjkgMjQgMiAyNEgyMkMyMy4xIDI0IDI0IDIzLjEgMjQgMjJWMTNDMjQgMTIuNDUgMjMuNTUgMTIgMjMgMTJaIiBmaWxsPSJibGFjayIvPjwvZz48ZGVmcz48Y2xpcFBhdGggaWQ9ImNsaXAwXzMxXzkxIj48cmVjdCB3aWR0aD0iMjQiIGhlaWdodD0iMjQiIGZpbGw9IndoaXRlIi8+PC9jbGlwUGF0aD48L2RlZnM+PC9zdmc+");
  -webkit-mask-size: contain;
          mask-size: contain;
  width: 12px;
  position: absolute;
  top: 0;
  right: 0;
}

.menu-button-block {
  background-color: #1c1c1c;
  line-height: 1;
  height: 42px;
}

.menu-toggle-button,
.menu-toggle-button span {
  display: inline-block;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.menu-toggle-button {
  background-color: #1c1c1c;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  position: relative;
  width: 42px;
  height: 100%;
}
.menu-toggle-button:focus, .menu-toggle-button:active {
  background-color: #1c1c1c;
}

.menu-toggle-button span {
  background-color: #fff;
  border-radius: calc(infinity * 1px);
  position: absolute;
  left: 50%;
  height: 2px;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 50%;
}

.menu-toggle-button span:nth-of-type(1) {
  top: 14px;
}

.menu-toggle-button span:nth-of-type(2) {
  top: 50%;
}

.menu-toggle-button span:nth-of-type(3) {
  bottom: 12px;
}

.menu-toggle-button.button-active span:nth-of-type(1) {
  left: 25%;
  -webkit-transform: translateY(6px) rotate(-45deg);
          transform: translateY(6px) rotate(-45deg);
}

.menu-toggle-button.button-active span:nth-of-type(2) {
  opacity: 0;
}

.menu-toggle-button.button-active span:nth-of-type(3) {
  left: 25%;
  -webkit-transform: translateY(-8px) rotate(45deg);
          transform: translateY(-8px) rotate(45deg);
}

.global-menu-block {
  background-color: #fff;
  height: 0;
  margin: 0;
  overflow: hidden;
  visibility: hidden;
  opacity: 0;
  -webkit-transition: opacity 0.2s ease-in-out, visibility 0.2s ease-in-out;
  transition: opacity 0.2s ease-in-out, visibility 0.2s ease-in-out;
  width: 100%;
}
.global-menu-block .primary-navi {
  padding: 0 20px;
}
.global-menu-block .primary-navi a {
  display: block;
  font-size: 20px;
}
.global-menu-block .global-sub-navigation {
  border-top: 1px solid #ddd;
  margin: 32px 0 0;
}
.global-menu-block .secondary-navi {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 16px;
  padding: 24px 20px 32px;
}
.global-menu-block .secondary-navi a {
  color: #1c1c1c;
  display: inline-block;
}
.global-menu-block .secondary-navi a::after {
  background-color: #1c1c1c;
  top: 4px;
}

.global-menu-block.global-menu-open {
  margin: 32px 0 0;
  height: auto;
  opacity: 1;
  visibility: visible;
}

.breadcrumbs {
  background-color: transparent;
  width: 100%;
}

.breadcrumbs span[property=name].current-item {
  display: inline-block;
  padding: 0;
  margin-top: -3px;
  vertical-align: middle;
  max-width: 215px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.breadcrumbs-list {
  font-size: 12px;
  line-height: 1.4;
  list-style: none;
  margin: 0 auto;
  padding: 16px 20px;
  width: 100%;
}
.breadcrumbs-list li {
  display: inline;
  position: relative;
}
.breadcrumbs-list li:nth-child(n+2)::after {
  content: "/";
  display: block;
  position: absolute;
  top: 50%;
  left: -15px;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}
.breadcrumbs-list li + li {
  margin: 0 0 0 24px;
}
.breadcrumbs-list li a {
  color: #1c1c1c;
  font-weight: 700;
  text-decoration: underline;
  -webkit-transition: color 0.2s ease-in-out;
  transition: color 0.2s ease-in-out;
}

/* TOPページ（ Business / Company のタイトル装飾 ） */
.section-title-block {
  font-weight: 700;
  margin: 0 auto;
  max-width: 1152px;
  width: 100%;
}
.section-title-block .section-title {
  font-family: "Roboto Condensed", sans-serif;
  font-size: clamp(4.5rem, 2rem + 11.11vw, 10rem);
  line-height: 1.2;
  margin: 0;
  padding: 0 0 8px 0;
}
.section-title-block .section-overview {
  border-top: 1px solid #1c1c1c;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 12px;
  font-family: "Noto Sans JP", sans-serif;
  padding: 12px 0 0;
}
.section-title-block .section-overview-title {
  font-size: clamp(1.5rem, 1.273rem + 1.01vw, 2rem);
}
.section-title-block .section-overview-text {
  font-size: clamp(1rem, 0.773rem + 1.01vw, 1.5rem);
  font-weight: 400;
  letter-spacing: -0.01em;
}

/* 下層ページ（ News一覧 / News詳細 冒頭のタイトル装飾 ） */
.post-name-block {
  font-weight: 700;
  line-height: 1.4;
  margin: 40px auto 0;
  max-width: 1152px;
  width: calc(100% - 40px);
}
.post-name-block .post-name {
  font-family: "Roboto Condensed", sans-serif;
  font-size: clamp(2.5rem, 1.818rem + 3.03vw, 4rem);
  margin: 0;
  padding: 0 0 4px 0;
}
.post-name-block .post-sub-name {
  border-top: 1px solid #1c1c1c;
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(1rem, 0.773rem + 1.01vw, 1.5rem);
  padding: 16px 0 0 0;
}

/* TOPページ（News / MEキャンパス / SPRIX学園 コンテンツ背景）、下層ページ（News一覧 / News詳細 コンテンツ背景） */
.bg-round {
  position: relative;
  width: 100%;
}

.round-r::after,
.round-l::after {
  background-color: #fff;
  content: "";
  display: block;
  height: 100%;
  position: absolute;
  top: 0;
  width: 100%;
}

.round-r::after {
  border-radius: 0 24px 24px 0;
  left: 0;
}

.round-l::after {
  border-radius: 24px 0 0 24px;
  right: 0;
}

/*  下層ページ（News詳細 記事タイトル付近）  */
.sns-links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 16px;
  margin: 32px 0 0;
}

/* リンクボタン（各ページ内） */
.link-button {
  background-color: #1c1c1c;
  border-radius: calc(infinity * 1px);
  color: #fff;
  display: inline-block;
  font-size: clamp(0.875rem, 0.761rem + 0.51vw, 1.125rem);
  font-weight: 700;
  overflow: hidden;
  padding: 16px 32px;
  position: relative;
  text-align: center;
}
.link-button::after {
  background-color: #00a3ff;
  border-radius: calc(infinity * 1px);
  content: "";
  display: block;
  height: 100%;
  opacity: 0;
  padding: 100% 0 0;
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  -webkit-transform: translateY(-50%) scale(0.1);
          transform: translateY(-50%) scale(0.1);
  -webkit-transition: opacity 0.2s, -webkit-transform 0s;
  transition: opacity 0.2s, -webkit-transform 0s;
  transition: opacity 0.2s, transform 0s;
  transition: opacity 0.2s, transform 0s, -webkit-transform 0s;
  -webkit-transition-delay: 0s, 0.2s;
          transition-delay: 0s, 0.2s;
  width: 100%;
  z-index: 0;
}

/* リンクボタン + 「別窓」アイコン付与 */
.icon-blank {
  display: inline-block;
  padding: 0 32px 0 0;
  position: relative;
  z-index: 1;
}
.icon-blank::after {
  background: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjQiIGhlaWdodD0iMjQiIHZpZXdCb3g9IjAgMCAyNCAyNCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48ZyBjbGlwLXBhdGg9InVybCgjY2xpcDBfMzFfOTEpIj48cGF0aCBkPSJNMjIgMEgxNy44M0MxNy4yOCAwIDE2LjgzIDAuNDUgMTYuODMgMUMxNi44MyAxLjU1IDE3LjI4IDIgMTcuODMgMkgyMC4zOUwxMS4xOSAxMS4yQzEwLjggMTEuNTkgMTAuOCAxMi4yMiAxMS4xOSAxMi42MUMxMS4zOSAxMi44MSAxMS42NCAxMi45IDExLjkgMTIuOUMxMi4xNiAxMi45IDEyLjQxIDEyLjggMTIuNjEgMTIuNjFMMjIgMy4yMlY2LjE3QzIyIDYuNzIgMjIuNDUgNy4xNyAyMyA3LjE3QzIzLjU1IDcuMTcgMjQgNi43MiAyNCA2LjE3VjJDMjQgMC45IDIzLjEgMCAyMiAwWiIgZmlsbD0iYmxhY2siLz48cGF0aCBkPSJNMjMgMTJDMjIuNDUgMTIgMjIgMTIuNDUgMjIgMTNWMjJIMlYySDExQzExLjU1IDIgMTIgMS41NSAxMiAxQzEyIDAuNDUgMTEuNTUgMCAxMSAwSDJDMC45IDAgMCAwLjkgMCAyVjIyQzAgMjMuMSAwLjkgMjQgMiAyNEgyMkMyMy4xIDI0IDI0IDIzLjEgMjQgMjJWMTNDMjQgMTIuNDUgMjMuNTUgMTIgMjMgMTJaIiBmaWxsPSJibGFjayIvPjwvZz48ZGVmcz48Y2xpcFBhdGggaWQ9ImNsaXAwXzMxXzkxIj48cmVjdCB3aWR0aD0iMjQiIGhlaWdodD0iMjQiIGZpbGw9IndoaXRlIi8+PC9jbGlwUGF0aD48L2RlZnM+PC9zdmc+") #fff 50% 50%/14px auto no-repeat;
  border-radius: 50%;
  color: #1c1c1c;
  content: "";
  display: block;
  height: 32px;
  line-height: 1;
  position: absolute;
  top: 50%;
  right: -16px;
  text-align: center;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
  width: 32px;
}

/* リンクボタン + 「戻る」アイコン付与 */
.icon-return {
  display: inline-block;
  padding: 0 0 0 32px;
  position: relative;
  z-index: 1;
}
.icon-return::after {
  background-color: #fff;
  border-radius: 50%;
  color: #1c1c1c;
  content: "←";
  display: block;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 400;
  height: 32px;
  line-height: 1;
  padding: 7px 0 0 0;
  position: absolute;
  top: 50%;
  left: 8px;
  text-align: center;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 32px;
}

/* テキストリンク（各ページ内｜テキストリンク + 矢印アイコン） */
.text-link {
  color: #1c1c1c;
  font-family: "Roboto Condensed", sans-serif;
  text-decoration: underline;
  text-decoration-color: transparent;
  -webkit-transition: text-decoration-color 0.2s ease-in-out;
  transition: text-decoration-color 0.2s ease-in-out;
}
.text-link .text-link-text {
  padding: 0 48px 0 0;
  position: relative;
}
.text-link .text-link-text::after {
  background-color: #1c1c1c;
  border-radius: 50%;
  content: "→";
  color: #fff;
  display: block;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 400;
  height: 32px;
  line-height: 1;
  padding: 7px 0 0 0;
  position: absolute;
  top: 45%;
  right: -16px;
  text-align: center;
  -webkit-transform: translate(-50%, -50%) scale(100%);
          transform: translate(-50%, -50%) scale(100%);
  -webkit-transition: -webkit-transform 0.2s ease-in-out;
  transition: -webkit-transform 0.2s ease-in-out;
  transition: transform 0.2s ease-in-out;
  transition: transform 0.2s ease-in-out, -webkit-transform 0.2s ease-in-out;
  width: 32px;
}

/* テキストリンク（各ページ内｜テキストリンク + 別窓アイコン） */
.blank-text-link {
  color: #1c1c1c;
  font-family: "Roboto Condensed", sans-serif;
  text-decoration: underline;
  text-decoration-color: transparent;
  -webkit-transition: text-decoration-color 0.2s ease-in-out;
  transition: text-decoration-color 0.2s ease-in-out;
}
.blank-text-link .blank-link-text {
  padding: 0 48px 0 0;
  position: relative;
}
.blank-text-link .blank-link-text::after {
  background: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjQiIGhlaWdodD0iMjQiIHZpZXdCb3g9IjAgMCAyNCAyNCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48ZyBjbGlwLXBhdGg9InVybCgjY2xpcDBfMzQ5XzI2NTQpIj48cGF0aCBkPSJNMjIgMEgxNy44M0MxNy4yOCAwIDE2LjgzIDAuNDUgMTYuODMgMUMxNi44MyAxLjU1IDE3LjI4IDIgMTcuODMgMkgyMC4zOUwxMS4xOSAxMS4yQzEwLjggMTEuNTkgMTAuOCAxMi4yMiAxMS4xOSAxMi42MUMxMS4zOSAxMi44MSAxMS42NCAxMi45IDExLjkgMTIuOUMxMi4xNiAxMi45IDEyLjQxIDEyLjggMTIuNjEgMTIuNjFMMjIgMy4yMlY2LjE3QzIyIDYuNzIgMjIuNDUgNy4xNyAyMyA3LjE3QzIzLjU1IDcuMTcgMjQgNi43MiAyNCA2LjE3VjJDMjQgMC45IDIzLjEgMCAyMiAwWiIgZmlsbD0id2hpdGUiLz48cGF0aCBkPSJNMjMgMTJDMjIuNDUgMTIgMjIgMTIuNDUgMjIgMTNWMjJIMlYySDExQzExLjU1IDIgMTIgMS41NSAxMiAxQzEyIDAuNDUgMTEuNTUgMCAxMSAwSDJDMC45IDAgMCAwLjkgMCAyVjIyQzAgMjMuMSAwLjkgMjQgMiAyNEgyMkMyMy4xIDI0IDI0IDIzLjEgMjQgMjJWMTNDMjQgMTIuNDUgMjMuNTUgMTIgMjMgMTJaIiBmaWxsPSJ3aGl0ZSIvPjwvZz48ZGVmcz48Y2xpcFBhdGggaWQ9ImNsaXAwXzM0OV8yNjU0Ij48cmVjdCB3aWR0aD0iMjQiIGhlaWdodD0iMjQiIGZpbGw9IndoaXRlIi8+PC9jbGlwUGF0aD48L2RlZnM+PC9zdmc+") #1c1c1c 50% 50%/14px auto no-repeat;
  border-radius: 50%;
  content: "";
  display: block;
  height: 32px;
  line-height: 1;
  padding: 7px 0 0 0;
  position: absolute;
  top: 45%;
  right: -16px;
  text-align: center;
  -webkit-transform: translate(-50%, -50%) scale(100%);
          transform: translate(-50%, -50%) scale(100%);
  -webkit-transition: -webkit-transform 0.2s ease-in-out;
  transition: -webkit-transform 0.2s ease-in-out;
  transition: transform 0.2s ease-in-out;
  transition: transform 0.2s ease-in-out, -webkit-transform 0.2s ease-in-out;
  width: 32px;
}

/*  News一覧、News詳細　カテゴリー表示、投稿日時表示  */
.post-meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.post-category {
  color: #1c1c1c;
  font-size: 12px;
  font-weight: 700;
  padding: 0 16px 0 0;
}

.post-time {
  border-left: 1px solid #ddd;
  font-size: 14px;
  font-weight: 700;
  padding: 0 0 0 16px;
}

.post-link {
  color: #1c1c1c;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 16px;
  -webkit-transition: color 0.2s ease-in-out;
  transition: color 0.2s ease-in-out;
}
.post-link .post-thumbnail {
  border: 1px solid #e9e9e9;
}
.post-link .post-thumbnail img {
  -webkit-transform: scale(100%);
          transform: scale(100%);
  -webkit-transition: -webkit-transform 0.2s ease-in-out;
  transition: -webkit-transform 0.2s ease-in-out;
  transition: transform 0.2s ease-in-out;
  transition: transform 0.2s ease-in-out, -webkit-transform 0.2s ease-in-out;
}
.post-link .post-time {
  color: #1c1c1c;
}
.post-link .post-title {
  font-size: clamp(1rem, 0.943rem + 0.25vw, 1.125rem);
  margin: 8px 0 0;
}

/* 下層ページ（News詳細） */
/* 下層ページ（News詳細 投稿の前後移動リンク） */
/* ページネーション（News一覧など） */
.wp-pagenavi {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 16px;
  margin: 64px auto 0;
  padding: 0 0 56px;
  position: relative;
  width: 100%;
}
.wp-pagenavi .previouspostslink,
.wp-pagenavi .nextpostslink {
  color: #1c1c1c;
  display: block;
  font-size: 14px;
  font-family: "Roboto Condensed", sans-serif;
  position: absolute;
  bottom: 0;
  text-decoration: underline;
  text-decoration-color: transparent;
  -webkit-transition: text-decoration-color 0.2s ease-in-out;
  transition: text-decoration-color 0.2s ease-in-out;
}
.wp-pagenavi .previouspostslink::after,
.wp-pagenavi .nextpostslink::after {
  background-color: #1c1c1c;
  border-radius: 50%;
  color: #fff;
  display: block;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  font-weight: 400;
  height: 28px;
  line-height: 1;
  padding: 7px 0 0 0;
  position: absolute;
  top: 45%;
  text-align: center;
  -webkit-transform: translate(-50%, -50%) scale(100%);
          transform: translate(-50%, -50%) scale(100%);
  -webkit-transition: -webkit-transform 0.2s ease-in-out;
  transition: -webkit-transform 0.2s ease-in-out;
  transition: transform 0.2s ease-in-out;
  transition: transform 0.2s ease-in-out, -webkit-transform 0.2s ease-in-out;
  width: 28px;
}
.wp-pagenavi .previouspostslink {
  margin: 0;
  left: 32px;
  width: auto;
}
.wp-pagenavi .previouspostslink::after {
  content: "←";
  left: -20px;
}
.wp-pagenavi .nextpostslink {
  margin: 0;
  text-align: right;
  right: 32px;
  width: auto;
}
.wp-pagenavi .nextpostslink::after {
  content: "→";
  right: -52px;
}
.wp-pagenavi .page,
.wp-pagenavi .current,
.wp-pagenavi .extend {
  border-radius: 50%;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-family: "Roboto Condensed", sans-serif;
  font-weight: 700;
  font-size: clamp(0.875rem, 0.761rem + 0.51vw, 1.125rem);
  line-height: 1;
  height: 32px;
  padding: 16px;
  text-align: center;
  width: 32px;
}
.wp-pagenavi .page {
  background-color: #f5f5f5;
  color: #1c1c1c;
  -webkit-transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
  transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
}
.wp-pagenavi .current {
  background-color: #00a3ff;
  color: #fff;
}
.wp-pagenavi .extend {
  background-color: #f5f5f5;
  color: #1c1c1c;
}

.not-found-body {
  margin: 32px 0 64px;
}

.not-found-inner {
  padding: 40px 20px;
  position: relative;
  margin: 0 auto;
  max-width: 1152px;
  width: 100%;
  z-index: 1;
}

.no-results,
.not-found {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 16px;
  max-width: 800px;
  margin: 0 auto;
  padding: 0 20px;
  width: 100%;
}

.no-results-title,
.not-found-title {
  font-size: clamp(1.5rem, 1.273rem + 1.01vw, 2rem);
  margin: 0;
}

.return-button {
  margin: 24px 0 0;
}

/* 下層ページ（投稿詳細） */
.post-body {
  margin: 32px 0 64px;
}

.post-body-inner {
  padding: 40px 20px;
  position: relative;
  margin: 0 auto;
  max-width: 800px;
  width: 100%;
  z-index: 1;
}

.post-title {
  font-weight: 400;
  font-size: clamp(1.5rem, 1.273rem + 1.01vw, 2rem);
  margin: 16px 0 0;
}

.post-thumbnail-block {
  margin: 40px 0 0;
}
.post-thumbnail-block .post-thumbnail {
  overflow: hidden;
}
.post-thumbnail-block .post-thumbnail.no-image {
  border: 1px solid #e9e9e9;
}

/* 下層ページ（投稿の前後移動リンク） */
.post-navi-block {
  margin: 40px auto 0;
  width: 100%;
}

.post-navi-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 40px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.navi-archives {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
  text-align: center;
  width: 100%;
}
.navi-prev a,
.navi-next a {
  color: #1c1c1c;
  display: block;
  font-family: "Roboto Condensed", sans-serif;
  position: relative;
  text-decoration: underline;
  text-decoration-color: transparent;
  -webkit-transition: text-decoration-color 0.2s ease-in-out;
  transition: text-decoration-color 0.2s ease-in-out;
}
.navi-prev a::after,
.navi-next a::after {
  background-color: #1c1c1c;
  border-radius: 50%;
  color: #fff;
  display: block;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 400;
  height: 32px;
  line-height: 1;
  padding: 7px 0 0 0;
  position: absolute;
  top: 45%;
  text-align: center;
  -webkit-transform: translate(-50%, -50%) scale(100%);
          transform: translate(-50%, -50%) scale(100%);
  -webkit-transition: -webkit-transform 0.2s ease-in-out;
  transition: -webkit-transform 0.2s ease-in-out;
  transition: transform 0.2s ease-in-out;
  transition: transform 0.2s ease-in-out, -webkit-transform 0.2s ease-in-out;
  width: 32px;
}

.navi-prev {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
  padding: 0 0 0 48px;
}
.navi-prev a::after {
  content: "←";
  left: -32px;
}

.navi-next {
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
  padding: 0 48px 0 0;
}
.navi-next a {
  text-align: right;
}
.navi-next a::after {
  content: "→";
  right: -64px;
}

/* 下層ページ（SNSリンク） */
.sns-links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 16px;
  margin: 32px 0 0;
}

.widget {
  margin: 0 0 1.5rem;
}
.widget select {
  max-width: 100%;
}

.page-content .wp-smiley,
.entry-content .wp-smiley,
.comment-content .wp-smiley {
  border: none;
  margin-bottom: 0;
  margin-top: 0;
  padding: 0;
}

.wp-caption {
  margin: 0.5rem 0 0;
  max-width: 100%;
}

.wp-caption-text {
  text-align: center;
}

/* スクリーンリーダー用テキスト */
.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute !important;
  width: 1px;
  word-wrap: normal !important;
}
.screen-reader-text:focus {
  background-color: #f1f1f1;
  border-radius: 3px;
  -webkit-box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
          box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
  clip: auto !important;
  clip-path: none;
  color: #21759b;
  display: block;
  font-size: 0.875rem;
  font-weight: 700;
  height: auto;
  left: 5px;
  line-height: normal;
  padding: 16px 24px;
  text-decoration: none;
  top: 5px;
  width: auto;
  z-index: 100000;
}

/* スキップリンクターゲット用設定 */
#primary[tabindex="-1"]:focus {
  outline: 0;
}

.pc {
  display: none;
}
@media screen and (min-width: 600px){
  .breadcrumbs span[property=name].current-item {
    max-width: 600px;
  }
  .post-link {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 24px;
  }
  .post-link .post-thumbnail-block {
    width: 27.77777777%;
  }
  .post-link .post-outline {
    width: calc(100% - 24px - 27.77777777%);
  }
  .wp-pagenavi .previouspostslink,
  .wp-pagenavi .nextpostslink {
    position: relative;
    font-size: 16px;
  }
  .wp-pagenavi .previouspostslink::after,
  .wp-pagenavi .nextpostslink::after {
    font-size: 18px;
    height: 48px;
    padding: 14px 0 0 0;
    width: 48px;
  }
  .wp-pagenavi .previouspostslink {
    -webkit-box-ordinal-group: unset;
        -ms-flex-order: unset;
            order: unset;
    margin: 0 56px 0 0;
  }
  .wp-pagenavi .previouspostslink::after {
    left: -40px;
  }
  .wp-pagenavi .nextpostslink {
    margin: 0 0 0 56px;
  }
  .wp-pagenavi .nextpostslink::after {
    right: -88px;
  }
  .wp-pagenavi .page,
  .wp-pagenavi .current,
  .wp-pagenavi .extend {
    height: 48px;
    padding: 16px;
    width: 48px;
  }
  .not-found-inner {
    padding: 40px;
  }
  .post-body-inner {
    padding: 40px;
  }
  .navi-archives {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    width: auto;
  }
  .navi-prev,
  .navi-next {
    min-width: 140px;
  }
  .navi-prev {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
}
@media screen and (min-width: 1000px){
  html {
    scroll-padding-top: 80px;
  }
  .global-header .global-header-inner {
    height: 80px;
    max-width: 94.444444444%;
  }
  .header-logo {
    margin: 0;
    width: 210px;
  }
  .footer-primary {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 160px 40px;
  }
  .footer-secondary {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    padding: 12px 40px;
  }
  .footer-secondary .secondary-navi {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 24px;
  }
  .page-top {
    padding: 32px 40px;
  }
  .main-contents {
    padding: 80px 0 0;
  }
  .primary-navi {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
  .menu-button-block {
    display: none;
  }
  .global-menu-block {
    background-color: transparent;
    height: auto;
    max-height: -webkit-fit-content;
    max-height: -moz-fit-content;
    max-height: fit-content;
    margin: 0 0 0 auto;
    visibility: visible;
    opacity: 1;
    width: auto;
  }
  .global-menu-block .primary-navi {
    gap: 40px;
  }
  .global-menu-block .primary-navi a {
    font-size: 18px;
  }
  .global-menu-block .global-sub-navigation {
    display: none;
  }
  .breadcrumbs span[property=name].current-item {
    max-width: 800px;
  }
  .breadcrumbs-list {
    width: calc(100% - 80px);
  }
  .section-title-block {
    margin: 0 auto;
  }
  .post-name-block {
    margin: 80px auto 0;
  }
  .round-r::after,
  .round-l::after {
    width: calc(100% - 20px);
  }
  .round-r::after {
    border-radius: 0 80px 80px 0;
  }
  .round-l::after {
    border-radius: 80px 0 0 80px;
  }
  .sns-links {
    margin: 48px 0 0;
  }
  .link-button {
    padding: 16px 40px;
  }
  .wp-pagenavi {
    margin: 120px auto 0;
  }
  .not-found-body {
    margin: 48px 0 80px;
  }
  .not-found-inner {
    padding: 64px 80px;
  }
  .no-results,
  .not-found {
    padding: 0;
  }
  .post-body {
    margin: 48px 0 80px;
  }
  .post-body-inner {
    padding: 64px 0;
  }
  .post-title {
    margin: 24px 0 0;
  }
  .post-thumbnail-block {
    margin: 64px 0 0;
  }
  .post-navi-block {
    margin: 120px auto 0;
  }
  .sns-links {
    margin: 48px 0 0;
  }
  .sp {
    display: none;
  }
  .pc {
    display: block;
  }
}
@media screen and (min-width: 1200px){
  .footer-logo {
    width: 360px;
  }
  .breadcrumbs span[property=name].current-item {
    max-width: 1000px;
  }
  .section-title-block .section-overview {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    gap: 40px;
    padding: 32px 0 0;
  }
  .round-r::after,
  .round-l::after {
    width: calc(100% - 40px);
  }
  .not-found-inner {
    padding: 64px 24px;
  }
}
@media screen and (min-width: 1440px){
  .not-found-inner {
    padding: 64px 0;
  }
}
@media (any-hover: hover){
  a:where(:-moz-any-link, :enabled, summary):hover {
    outline: 0;
    text-decoration-color: #00a3ff;
  }
  a:where(:any-link, :enabled, summary):hover {
    outline: 0;
    text-decoration-color: #00a3ff;
  }
  button:where(:-moz-any-link, :enabled, summary):hover, input[type=button]:where(:-moz-any-link, :enabled, summary):hover, input[type=reset]:where(:-moz-any-link, :enabled, summary):hover, input[type=submit]:where(:-moz-any-link, :enabled, summary):hover {
    background-color: #fff;
    border-color: #bbb;
  }
  button:where(:any-link, :enabled, summary):hover,
  input[type=button]:where(:any-link, :enabled, summary):hover,
  input[type=reset]:where(:any-link, :enabled, summary):hover,
  input[type=submit]:where(:any-link, :enabled, summary):hover {
    background-color: #fff;
    border-color: #bbb;
  }
  .footer-secondary .secondary-navi a:where(:-moz-any-link, :enabled, summary):hover {
    outline: 0;
    text-decoration-color: #fff;
  }
  .footer-secondary .secondary-navi a:where(:any-link, :enabled, summary):hover {
    outline: 0;
    text-decoration-color: #fff;
  }
  .page-top .page-top-link:where(:-moz-any-link, :enabled, summary):hover {
    text-decoration-color: #1c1c1c;
  }
  .page-top .page-top-link:where(:any-link, :enabled, summary):hover {
    text-decoration-color: #1c1c1c;
  }
  .page-top .page-top-link:where(:-moz-any-link, :enabled, summary):hover .page-top-text::after {
    background-color: #00a3ff;
    transform: translate(-50%, -50%) scale(115%);
  }
  .page-top .page-top-link:where(:any-link, :enabled, summary):hover .page-top-text::after {
    background-color: #00a3ff;
    -webkit-transform: translate(-50%, -50%) scale(115%);
            transform: translate(-50%, -50%) scale(115%);
  }
  .primary-navi a:where(:-moz-any-link, :enabled, summary):hover {
    background-size: 100% 2px;
    background-position: bottom left;
    color: #00a3ff;
  }
  .primary-navi a:where(:any-link, :enabled, summary):hover {
    background-size: 100% 2px;
    background-position: bottom left;
    color: #00a3ff;
  }
  .menu-toggle-button:where(:-moz-any-link, :enabled, summary):hover {
    background-color: #1c1c1c;
  }
  .menu-toggle-button:where(:any-link, :enabled, summary):hover {
    background-color: #1c1c1c;
  }
  .breadcrumbs-list li a:where(:-moz-any-link, :enabled, summary):hover {
    color: #00a3ff;
  }
  .breadcrumbs-list li a:where(:any-link, :enabled, summary):hover {
    color: #00a3ff;
  }
  .link-button:where(:-moz-any-link, :enabled, summary):hover::after {
    opacity: 1;
    transform: translateY(-50%) scale(1.1);
    transition-delay: 0s;
    -moz-transition: opacity 0.2s, transform 0.2s ease-in-out;
    transition: opacity 0.2s, transform 0.2s ease-in-out;
  }
  .link-button:where(:any-link, :enabled, summary):hover::after {
    opacity: 1;
    -webkit-transform: translateY(-50%) scale(1.1);
            transform: translateY(-50%) scale(1.1);
    -webkit-transition-delay: 0s;
            transition-delay: 0s;
    -webkit-transition: opacity 0.2s, -webkit-transform 0.2s ease-in-out;
    transition: opacity 0.2s, -webkit-transform 0.2s ease-in-out;
    transition: opacity 0.2s, transform 0.2s ease-in-out;
    transition: opacity 0.2s, transform 0.2s ease-in-out, -webkit-transform 0.2s ease-in-out;
  }
  .text-link:where(:-moz-any-link, :enabled, summary):hover {
    text-decoration-color: #1c1c1c;
  }
  .text-link:where(:any-link, :enabled, summary):hover {
    text-decoration-color: #1c1c1c;
  }
  .text-link:where(:-moz-any-link, :enabled, summary):hover .text-link-text::after {
    background-color: #00a3ff;
    transform: translate(-50%, -50%) scale(115%);
  }
  .text-link:where(:any-link, :enabled, summary):hover .text-link-text::after {
    background-color: #00a3ff;
    -webkit-transform: translate(-50%, -50%) scale(115%);
            transform: translate(-50%, -50%) scale(115%);
  }
  .blank-text-link:where(:-moz-any-link, :enabled, summary):hover {
    text-decoration-color: #1c1c1c;
  }
  .blank-text-link:where(:any-link, :enabled, summary):hover {
    text-decoration-color: #1c1c1c;
  }
  .blank-text-link:where(:-moz-any-link, :enabled, summary):hover .blank-link-text::after {
    background-color: #00a3ff;
    transform: translate(-50%, -50%) scale(115%);
  }
  .blank-text-link:where(:any-link, :enabled, summary):hover .blank-link-text::after {
    background-color: #00a3ff;
    -webkit-transform: translate(-50%, -50%) scale(115%);
            transform: translate(-50%, -50%) scale(115%);
  }
  .post-link:where(:-moz-any-link, :enabled, summary):hover {
    color: #00a3ff;
    text-decoration: none;
    text-decoration-color: transparent;
  }
  .post-link:where(:any-link, :enabled, summary):hover {
    color: #00a3ff;
    text-decoration: none;
    text-decoration-color: transparent;
  }
  .post-link:where(:-moz-any-link, :enabled, summary):hover .post-thumbnail img {
    transform: scale(105%);
  }
  .post-link:where(:any-link, :enabled, summary):hover .post-thumbnail img {
    -webkit-transform: scale(105%);
            transform: scale(105%);
  }
  .wp-pagenavi .previouspostslink:where(:-moz-any-link, :enabled, summary):hover, .wp-pagenavi .nextpostslink:where(:-moz-any-link, :enabled, summary):hover {
    text-decoration-color: #1c1c1c;
  }
  .wp-pagenavi .previouspostslink:where(:any-link, :enabled, summary):hover,
  .wp-pagenavi .nextpostslink:where(:any-link, :enabled, summary):hover {
    text-decoration-color: #1c1c1c;
  }
  .wp-pagenavi .previouspostslink:where(:-moz-any-link, :enabled, summary):hover::after, .wp-pagenavi .nextpostslink:where(:-moz-any-link, :enabled, summary):hover::after {
    background-color: #00a3ff;
    transform: translate(-50%, -50%) scale(115%);
  }
  .wp-pagenavi .previouspostslink:where(:any-link, :enabled, summary):hover::after,
  .wp-pagenavi .nextpostslink:where(:any-link, :enabled, summary):hover::after {
    background-color: #00a3ff;
    -webkit-transform: translate(-50%, -50%) scale(115%);
            transform: translate(-50%, -50%) scale(115%);
  }
  .wp-pagenavi .page:where(:-moz-any-link, :enabled, summary):hover {
    background-color: #00a3ff;
    color: #fff;
    text-decoration-color: transparent;
  }
  .wp-pagenavi .page:where(:any-link, :enabled, summary):hover {
    background-color: #00a3ff;
    color: #fff;
    text-decoration-color: transparent;
  }
  .navi-prev a:where(:-moz-any-link, :enabled, summary):hover, .navi-next a:where(:-moz-any-link, :enabled, summary):hover {
    text-decoration-color: #1c1c1c;
  }
  .navi-prev a:where(:any-link, :enabled, summary):hover,
  .navi-next a:where(:any-link, :enabled, summary):hover {
    text-decoration-color: #1c1c1c;
  }
  .navi-prev a:where(:-moz-any-link, :enabled, summary):hover::after, .navi-next a:where(:-moz-any-link, :enabled, summary):hover::after {
    background-color: #00a3ff;
    transform: translate(-50%, -50%) scale(115%);
  }
  .navi-prev a:where(:any-link, :enabled, summary):hover::after,
  .navi-next a:where(:any-link, :enabled, summary):hover::after {
    background-color: #00a3ff;
    -webkit-transform: translate(-50%, -50%) scale(115%);
            transform: translate(-50%, -50%) scale(115%);
  }
}
