@charset "UTF-8";
/*--------------------------------------*
 * foundation
 *--------------------------------------*/
/* Google Fonts
--------------------------- */
@import url("//fonts.googleapis.com/css?family=Noto+Sans+JP:300,400,500,600,700&display=swap");
@import url("//fonts.googleapis.com/css?family=Noto+Serif+JP:300,400,500,600,700&display=swap");
@import url("https://fonts.googleapis.com/icon?family=Material+Icons");
/* system
--------------------------- */
@import url("https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&display=swap");
/* reset
--------------------------- */
/*
 * destyle.css v1.0.14
 * https://github.com/nicolas-cusan/destyle.css
 */
::after,
::before {
  -webkit-box-sizing: inherit;
          box-sizing: inherit;
}

html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
}

body {
  margin: 0;
}

main {
  display: block;
}

address,
blockquote,
dl,
figure,
form,
iframe,
p,
pre,
table {
  margin: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
  margin: 0;
}

ol,
ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

dt {
  font-weight: normal;
}

dd {
  margin-left: 0;
}

hr {
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  height: 0;
  overflow: visible;
  border: 0;
  border-top: 1px solid;
  margin: 0;
  clear: both;
  color: inherit;
}

pre {
  font-family: monospace, monospace;
  font-size: inherit;
}

address {
  font-style: inherit;
}

a {
  background-color: transparent;
  text-decoration: none;
  color: inherit;
}

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: inherit;
}

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;
  vertical-align: bottom;
}

embed,
iframe,
object {
  border: 0;
  vertical-align: bottom;
}

button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  border: 0;
  background: 0 0;
  padding: 0;
  margin: 0;
  border-radius: 0;
  text-align: inherit;
}

[type=checkbox] {
  -webkit-appearance: checkbox;
  -moz-appearance: checkbox;
       appearance: checkbox;
}

[type=radio] {
  -webkit-appearance: radio;
  -moz-appearance: radio;
       appearance: radio;
}

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

[type=button],
[type=reset],
[type=submit],
button {
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
}

[type=button][disabled],
[type=reset][disabled],
[type=submit][disabled],
button[disabled] {
  cursor: default;
}

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

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

select::-ms-expand {
  display: none;
}

option {
  padding: 0;
}

fieldset {
  margin: 0;
  padding: 0;
  border: 0;
  min-width: 0;
}

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

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

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

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

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

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

label[for] {
  cursor: pointer;
}

details {
  display: block;
}

summary {
  display: list-item;
}

[contenteditable] {
  outline: 0;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

caption {
  text-align: left;
}

td,
th {
  vertical-align: top;
  padding: 0;
}

th {
  text-align: left;
  font-weight: 700;
}

template {
  display: none;
}

[hidden] {
  display: none;
}

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

body, html {
  margin: 0;
  padding: 0;
  height: 100%;
}

html {
  font-size: 62.5%;
  line-height: 1.6;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}

body {
  color: #3c3c3c;
  background-color: #ffffff;
  font-size: 16px;
  font-size: 1.6rem;
  font-family: "Roboto", "Noto Sans JP", sans-serif;
  font-weight: 400;
}

main section {
  padding: 80px 0;
  padding: 8rem 0;
}

img,
object {
  max-width: 100%;
  height: auto;
  border: none;
  display: block;
}

a {
  color: #0f54c3;
  position: relative;
}
a:hover {
  opacity: 0.65;
  text-decoration: none;
  cursor: pointer;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}

a:hover img {
  opacity: 0.65;
  text-decoration: none;
  cursor: pointer;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}

a,
label,
input,
button {
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}

.linkbox {
  position: relative;
}
.linkbox a {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}
.linkbox:hover {
  opacity: 0.8;
  cursor: pointer;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}

a.position_center {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}

article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
  display: block;
}

audio, canvas, progress, video {
  display: inline-block;
  vertical-align: baseline;
}

audio:not([controls]) {
  display: none;
  height: 0;
}

[hidden], template {
  display: none;
}

.red {
  color: #e31111;
}

.tab-group {
  display: grid;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  list-style-type: none;
  width: 100%;
  margin: 0 auto;
  padding: 0;
}

.tab {
  width: 100%;
  text-align: center;
  padding: 1.25em 0 0.75em;
  border-bottom: solid 3px #ffffff;
  cursor: pointer;
}
.tab[aria-selected=true] {
  background-color: rgba(239, 239, 239, .5);
  border-bottom: solid 3px #03A3EB;
}

.panel-group {
  border-top: none;
}

.panel {
  display: none;
  width: 100%;
  margin-inline: auto;
  padding: 35px;
  background-color: rgba(239, 239, 239, .2);
}
.panel[aria-hidden=false] {
  display: block;
  -webkit-animation: show 0.5s ease;
          animation: show 0.5s ease;
}

@-webkit-keyframes show {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes show {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
/**
* ===================================================================
* Typography
* ------------------------------------------------------------------- */
h1, h2, h3, h4, h5, h6 {
  font-style: normal;
  font-weight: 500;
  line-height: 1.3;
  margin: 0 0 0.75em;
}

h1, .h01 {
  font-size: 30px;
  font-size: 3rem;
}

h2, .h02 {
  font-size: 28px;
  font-size: 2.8rem;
}

h3, .h03 {
  font-size: 24px;
  font-size: 2.4rem;
}

h4, .h04 {
  font-size: 21px;
  font-size: 2.1rem;
}

h5, .h05 {
  font-size: 18px;
  font-size: 1.8rem;
}

h6, .h06 {
  font-size: 16px;
  font-size: 1.6rem;
}

p {
  margin: 0 0 1.25em;
}

b, strong {
  color: rgba(60, 60, 60, .95);
}

.plain {
  font-family: "Roboto", "Noto Sans JP", sans-serif;
  text-shadow: none;
  text-shadow: initial;
}

.serif {
  font-family: "Noto Serif JP", serif;
}

em, i, b {
  font-weight: normal;
  font-style: normal;
}

blockquote {
  position: relative;
  margin: 30px 0;
  margin: 3rem 0;
  padding-left: 40px;
  padding-left: 4rem;
}
blockquote:before {
  position: absolute;
  top: 30px;
  top: 3rem;
  left: 0;
  color: #3c3c3c;
  font-family: arial, sans-serif;
  font-size: 80px;
  font-size: 8rem;
  line-height: 0;
  content: "“";
  margin: 0;
}
blockquote p {
  font-family: "Noto Serif JP", serif;
  font-style: italic;
  padding: 0;
}
blockquote cite {
  display: block;
  font-size: 12px;
  font-size: 1.2rem;
  font-style: normal;
}
blockquote cite:before {
  content: "— ";
}
blockquote cite a {
  color: #8d8d8d;
  border: none;
}
blockquote cite a:visited {
  color: #8d8d8d;
  border: none;
}

code {
  white-space: nowrap;
  margin: 0 2px;
  margin: 0 0.2rem;
  padding: 3px 6px;
  padding: 0.3rem 0.6rem;
  border: 1px solid #e1e1e1;
  border-radius: 3px;
  background: #f1f1f1;
}

del {
  text-decoration: line-through;
}

abbr {
  color: #8d8d8d;
  -webkit-font-feature-settings: "c2sc";
          font-feature-settings: "c2sc";
  font-variant: small-caps;
  letter-spacing: 0.5px;
  letter-spacing: 0.05rem;
  text-transform: lowercase;
}

dfn {
  font-style: italic;
}

abbr[title], dfn[title] {
  cursor: help;
  border-bottom: dotted 1px #8c8c8c;
}

mark {
  background: #ff0;
  color: #000;
}

small, .small {
  font-size: 0.86em !important;
}

sub, sup {
  font-size: 10px;
  font-size: 1rem;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

.textCenter {
  text-align: center;
}

.textLeft {
  text-align: left;
}

.textRight {
  text-align: right;
}

.fin {
  margin-bottom: 80px !important;
  margin-bottom: 8rem !important;
}

.fin2 {
  margin-bottom: 1.5em !important;
}

.mb0 {
  margin-bottom: 0 !important;
}

.color-red {
  color: #e31111;
}

/**
* ===================================================================
* Images
* ------------------------------------------------------------------- */
img {
  border: 0;
}
img a:hover {
  opacity: 0.5;
  cursor: pointer;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
img.responsive {
  display: block;
  max-width: 100%;
  height: auto;
  width: auto;
}

.shadow {
  margin: 5px;
  -webkit-box-shadow: rgba(50, 50, 93, .1) 0px 8px 18px -3px, rgba(0, 0, 0, .1) 0px 5px 10px -5px;
          box-shadow: rgba(50, 50, 93, .1) 0px 8px 18px -3px, rgba(0, 0, 0, .1) 0px 5px 10px -5px;
}

svg:not(:root) {
  overflow: hidden;
}

/**
* ===================================================================
* ブランド
* ------------------------------------------------------------------- */
.main_logo {
  max-width: 600px;
  width: 42%;
}
.main_logo img {
  width: 100%;
}

/*--------------------------------------*
 * object
 *--------------------------------------*/
/*-------------------
 * component
  ------------------*/
/* c-loading
--------------------------- */
/* Container
--------------------------- */
.container {
  max-width: 1280px;
  width: 100%;
  margin: 0 auto;
  padding: 0;
}

.min-container {
  max-width: 960px;
  width: 100%;
  margin: 0 auto;
  padding: 0;
}

.full-container {
  width: 100%;
  margin: 0;
  padding: 0 1.5%;
}

/* Grid
--------------------------- */
.row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.position_center {
  display: grid;
  place-items: center;
}

.row_reverse {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}

.horizontal_center {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.vertical_center {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.space_between {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.row-grid {
  display: grid;
}

.row-two {
  grid-template-columns: 1fr 1fr;
}

.row-three {
  grid-template-columns: 1fr 1fr 1fr;
}

.row-four {
  grid-template-columns: 1fr 1fr 1fr 1fr;
}

.row-two,
.row-three,
.row-four {
  grid-gap: 5%;
}

/* c-section
--------------------------- */
.c-section {
  background-color: #ffffff;
  padding: 120px 0;
}
.c-section:nth-of-type(even) {
  background-color: #efefef;
}
.c-section__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 10px 20px;
}
.c-section__title {
  text-align: center;
  font-size: 28px;
  font-size: 2.8rem;
  font-weight: 700;
  margin: 0 auto 12px;
}
.c-section__lead {
  display: table;
  margin: 0 auto 32px;
  text-align: left;
}
.c-section__block {
  margin: 32px auto 0;
}
/* c-table
--------------------------- */
table {
  width: auto;
  line-height: 1.3;
  margin-bottom: 1em;
  border-width: 0;
  border-collapse: collapse;
  border-spacing: 0;
  background-color: #ffffff;
}
table.W100 {
  max-width: 100%;
  width: 100%;
}
table caption {
  text-align: left;
  margin-bottom: 0.35em;
}
table th, table td {
  text-align: left;
  vertical-align: middle;
  padding: 15px 30px;
  padding: 1.5rem 3rem;
}
table th {
  color: #3c3c3c;
  vertical-align: middle;
}
table thead {
  background-color: rgba(140, 140, 140, .1);
}
table thead th, table thead td {
  text-align: center;
  border-bottom: 1px solid rgba(76, 76, 76, .75);
}
table tbody tr:nth-child(2n) {
  background-color: rgba(239, 239, 239, .25);
}
table tbody th, table tbody td {
  border-bottom: 1px solid rgba(140, 140, 140, .35);
}
table tfoot {
  background-color: rgba(140, 140, 140, .2);
  border-top: 2px solid rgba(76, 76, 76, .35);
}

.table-container {
  position: relative;
  overflow-x: auto;
  white-space: nowrap;
}
.table-container table {
  margin-bottom: 4px;
}

.scroll-hint {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 48px;
  padding: 5px 10px;
  background-color: rgba(60, 60, 60, .5);
  border-radius: 3px;
  font-weight: 700;
  line-height: 1.4;
  display: none;
  -webkit-animation: scroll-hint-animation 2.5s infinite ease;
          animation: scroll-hint-animation 2.5s infinite ease;
}

@-webkit-keyframes scroll-hint-animation {
  0% {
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
  50% {
    -webkit-transform: translate(-20%, -50%);
            transform: translate(-20%, -50%);
  }
  100% {
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
}

@keyframes scroll-hint-animation {
  0% {
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
  50% {
    -webkit-transform: translate(-20%, -50%);
            transform: translate(-20%, -50%);
  }
  100% {
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
}
.scroll-hint--show {
  display: block;
}

/* List
--------------------------- */
ol li, ul li {
  line-height: 1.4;
}
ol.decimal, ul.decimal {
  list-style: decimal;
  margin-bottom: 0.5em;
  padding-left: 25px;
  padding-left: 2.5rem;
}
ol.decimal li, ul.decimal li {
  margin-bottom: 0.5em;
}
ol.decimal li:last-child, ul.decimal li:last-child {
  margin-bottom: 0;
}
ol.decimal li p, ul.decimal li p {
  margin: 0.3em 0 0.3em 0.5em;
}

li ul, li ol {
  margin-top: 0.35em;
}

ul.disc {
  list-style: disc;
  margin-bottom: 0.5em;
  padding-left: 27.5px;
  padding-left: 2.75rem;
}
ul.disc li {
  margin-bottom: 0.5em;
}
ul.disc li:last-child {
  margin-bottom: 0;
}
ul.disc li p {
  margin: 0.3em 0 0.3em 0.5em;
}

ul.circle {
  list-style: circle;
  margin-bottom: 0.5em;
  padding-left: 27.5px;
  padding-left: 2.75rem;
}
ul.circle li {
  margin-bottom: 0.5em;
}
ul.circle li:last-child {
  margin-bottom: 0;
}
ul.circle li p {
  margin: 0.3em 0 0.3em 0.5em;
}

ul.kome {
  padding-left: 25px;
  padding-left: 2.5rem;
}
ul.kome li {
  text-indent: -1.3em;
  margin-bottom: 0.25em;
}
ul.kome li:last-child {
  margin-bottom: 0;
}
ul.kome li:before {
  display: inline;
  content: "※";
  padding-right: 0.22em;
}
ul.kome li .decimal > li, ul.kome li .disc > li {
  padding-left: 25px;
  padding-left: 2.5rem;
}
ul.kome li .circle > li {
  padding-left: 17.5px;
  padding-left: 1.75rem;
}
ul.kome ul li:before, ul.kome ol li:before {
  content: none !important;
}
ul.kome ul.disc {
  padding-left: 30px;
  padding-left: 3rem;
}
ul.kome ul.disc li {
  padding-left: 1.25em;
}

ul.no-mark {
  margin-bottom: 0.5em;
}
ul.no-mark li {
  margin-bottom: 0.5em;
}
ul.no-mark li:last-child {
  margin-bottom: 0;
}
ul.no-mark li p {
  margin: 0.3em 0 0.3em 0.5em;
}

ol.alphabet {
  list-style: upper-alpha !important;
  margin-bottom: 0.5em;
  padding-left: 27.5px;
  padding-left: 2.75rem;
}
ol.alphabet li {
  margin-bottom: 0.5em;
}
ol.alphabet li:last-child {
  margin-bottom: 0;
}
ol.alphabet li p {
  margin: 0.3em 0 0.3em 0.5em;
}

dl.indent {
  margin-left: 0.65em;
}

div.indent {
  margin-left: 0.65em;
}

/* c-details
--------------------------- */
.alert {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 15px 25px;
  padding: 1.5rem 2.5rem;
  margin: 2em 0 1.35em 0.5em;
  -webkit-box-shadow: 0 0 8px rgba(153, 153, 153, .35);
          box-shadow: 0 0 8px rgba(153, 153, 153, .35);
  border: 1px solid transparent;
  border-radius: 0.25rem;
  color: #333;
  gap: 5px;
  gap: 0.5rem;
  line-height: 1.5;
}

.alert-success {
  border: 1px solid rgba(92, 189, 157, .5);
  border-left: 5px solid #5CBD9D;
  background-color: rgba(92, 189, 157, .05);
}

.alert-error {
  border: 1px solid rgba(231, 76, 60, .5);
  border-left: 5px solid #E74C3C;
  background-color: rgba(231, 76, 60, .05);
}

.alert-warning {
  border: 1px solid rgba(242, 156, 51, .5);
  border-left: 5px solid #F29C33;
  background-color: rgba(242, 156, 51, .05);
}

.alert-info {
  border: 1px solid rgba(57, 152, 219, .5);
  border-left: 5px solid #3998DB;
  background-color: rgba(57, 152, 219, .05);
}

.fa-check-circle {
  color: #5CBD9D;
}

.fa-times-circle {
  color: #E74C3C;
}

.fa-exclamation-triangle {
  color: #F29C33;
}

.fa-exclamation-circle {
  color: #3998DB;
}

/* c-table
--------------------------- */
.search_container {
  width: 100%;
  line-height: 1;
  border: 1px solid #999;
  padding: 13px 20px;
  margin-bottom: 75px;
  margin-bottom: 7.5rem;
  border-radius: 30px;
  background-color: #ffffff;
}
.search_container input[type=search] {
  border: none;
}
.search_container input[type=search]::-webkit-input-placeholder {
  color: #ccc;
}
.search_container input[type=search]::-moz-placeholder {
  color: #ccc;
}
.search_container input[type=search]::-ms-input-placeholder {
  color: #ccc;
}
.search_container input[type=search]::placeholder {
  color: #ccc;
}
.search_container input[type=search]:focus {
  outline: 0;
}
.search_container input[type=search]:focus::-webkit-input-placeholder {
  color: transparent;
}
.search_container input[type=search]:focus::-moz-placeholder {
  color: transparent;
}
.search_container input[type=search]:focus::-ms-input-placeholder {
  color: transparent;
}
.search_container input[type=search]:focus::placeholder {
  color: transparent;
}

/* 言語切り替え
--------------------------- */
.gtranslate_wrapper {
  display: none;
}

.group-brand .gtranslate_wrapper {
  display: block;
  padding-right: 1px;
}
.group-brand .gtranslate_wrapper .gt_switcher {
  width: 204px;
  border-radius: 0 0 4px 4px;
}
.group-brand .gtranslate_wrapper .gt_switcher .gt_selected a {
  width: 190px;
  padding: 5px 5px 5px 6px;
  background-color: #ffffff;
  border: solid 1px #ccc;
  border-radius: 4px;
}
.group-brand .gtranslate_wrapper .gt_switcher .gt_selected a::after {
  background: none;
  width: 11px;
  height: 11px;
  margin-top: 2px;
  border: 2px solid;
  border-color: transparent transparent #03A3EB #03A3EB;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  -webkit-transition: all 0.4s ease-out;
  transition: all 0.4s ease-out;
}
.group-brand .gtranslate_wrapper .gt_switcher .gt_selected a.open {
  padding: 8px 5px 8px 6px;
}
.group-brand .gtranslate_wrapper .gt_switcher .gt_selected a.open::after {
  margin-top: 9px;
  -webkit-transform: rotate(135deg);
          transform: rotate(135deg);
  -webkit-transition: all 0.4s ease-out;
  transition: all 0.4s ease-out;
}
.group-brand .gtranslate_wrapper .gt_switcher .gt_option {
  width: 202px;
  min-height: 230px;
}
.group-brand .gtranslate_wrapper .gt_switcher .gt_option a {
  font-size: 16px;
  padding: 8px 6px;
}
.group-brand .gtranslate_wrapper .gt_switcher a {
  font-size: 17px;
}
.group-brand .gtranslate_wrapper .gt_switcher a img {
  width: 21px;
  height: 21px;
  margin-right: 1em;
}
/* 言語切り替え
--------------------------- */
.events .event__list li p small {
  display: none;
}

html[lang=ja] .events .event__list li p small {
  display: block;
  color: #0E55C3;
  font-size: 13px !important;
  font-size: 1.3rem !important;
  margin-top: 0.5em;
}

/*-------------------
 * object
  ------------------*/
/**
* ===================================================================
* decoration
* ------------------------------------------------------------------- */
p.detailButton {
  margin-bottom: 0;
}
p.detailButton a:link, p.detailButton a:visited {
  color: #4c4c4c;
}
p.detailButton a {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  font-weight: 500;
  line-height: 3.5em;
}
p.detailButton a:after {
  content: "";
  display: inline-block;
  width: 1.8em;
  height: 2em;
  margin: 0.7em 0 0 0.7em;
  background: url("../img/common/circleRightArrow.svg") no-repeat bottom left;
  background-size: contain;
}

.text_shadow {
  text-shadow: 1px 1px 3px rgba(76, 76, 76, .2);
}

.pageLink {
  color: #3c3c3c;
  line-height: 1;
}
.pageLink::after {
  content: "";
  display: inline-block;
  width: 0.85em;
  height: 0.85em;
  margin: 0 0 0.25em 0.35em;
  background: url("../img/common/link.svg") no-repeat bottom right;
  background-size: contain;
  vertical-align: text-bottom;
}

.otherWindow {
  line-height: 1;
}
.otherWindow::after {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  margin: 0 0 0.2em 0.35em;
  background: url("../img/common/externalLink.svg") no-repeat bottom right;
  background-size: contain;
  vertical-align: text-bottom;
}
/* display
--------------------------- */
h2.title {
  color: #0E55C3;
  font-size: 25px;
  font-size: 2.5rem;
  font-weight: 500;
  letter-spacing: 15px;
  letter-spacing: 1.5rem;
  text-align: center;
  border-bottom: 3px solid #03A3EB;
  padding-left: 1%;
  padding-bottom: 18px;
  margin-bottom: 50px;
  position: relative;
}
h2.title.long {
  letter-spacing: 5px;
  letter-spacing: 0.5rem;
}
h2.title:before {
  content: "";
  background-color: #ffffff;
  width: 20px;
  height: 3px;
  position: absolute;
  bottom: -3px;
  left: 49.2%;
}
h2.title:after {
  content: "";
  background-color: #03A3EB;
  width: 20px;
  height: 3px;
  -webkit-transform: rotate(50deg);
          transform: rotate(50deg);
  position: absolute;
  bottom: -10px;
  left: calc(49.2% - 5px);
}

h2.title-blueback {
  color: #0E55C3;
  font-size: 25px;
  font-size: 2.5rem;
  font-weight: 500;
  letter-spacing: 15px;
  letter-spacing: 1.5rem;
  text-align: center;
  border-bottom: 3px solid #03A3EB;
  padding-left: 1%;
  padding-bottom: 18px;
  margin-bottom: 50px;
  position: relative;
}
h2.title-blueback.long {
  letter-spacing: 5px;
  letter-spacing: 0.5rem;
}
h2.title-blueback:before {
  content: "";
  background-color: #e5f5fd;
  width: 20px;
  height: 3px;
  position: absolute;
  bottom: -3px;
  left: 49.2%;
}
h2.title-blueback:after {
  content: "";
  background-color: #03A3EB;
  width: 20px;
  height: 3px;
  -webkit-transform: rotate(50deg);
          transform: rotate(50deg);
  position: absolute;
  bottom: -10px;
  left: calc(49.2% - 5px);
}

h2.title-small {
  color: #0E55C3;
  border: 1px solid #5785bc;
  font-weight: 400;
  font-size: 18px;
  font-size: 1.8rem;
  text-align: center;
  height: 35px;
  line-height: 35px;
  margin: 0;
}

h3.title {
  color: #ffffff;
  font-weight: 400;
  font-size: 20px;
  font-size: 2rem;
  min-height: 28px;
  padding-top: 0;
  padding-left: 30px;
  padding-bottom: 2px;
  margin: 70px 5px 30px;
  background: url(/manage/wp-content/themes/design/img/white-diagonal-line.svg) no-repeat top left;
  background-size: 26px;
  outline: 5px solid rgba(3, 163, 235, .6);
  background-color: rgba(3, 163, 235, .6);
}
h3.title.course {
  margin: 30px 5px 20px;
}
h3.title.course-short {
  margin: 30px 5px 12px;
}

h4.title {
  position: relative;
  color: #0E55C3;
  font-size: 20px;
  font-size: 2rem;
  font-weight: 500;
  margin: 50px auto 20px;
  margin: 50px auto 2rem;
  padding-left: 36px;
}
h4.title:before {
  display: block;
  position: absolute;
  left: 0;
  top: 3px;
  content: " ";
  width: 20px;
  height: 20px;
  background: url(/manage/wp-content/themes/design/img/blue-diagonal-mark.svg) no-repeat;
}
h4.title.course {
  margin: 25px 0 12px;
}

.detailsAnimation .details-content {
  overflow: hidden;
}
.detailsAnimation summary {
  cursor: pointer;
  position: relative;
  -webkit-transition: background-color 0.3s;
  transition: background-color 0.3s;
}
.detailsAnimation summary::-webkit-details-marker {
  display: none;
}

/* Container
--------------------------- */
.breadcrumbs {
  line-height: 1;
  padding-block: 0.5em;
}
.breadcrumbs li:not(:last-of-type)::after {
  content: "/";
  margin: 0 0.75em; /* 記号の左右の余白 */
  color: #777; /* 記号の色 */
}
/*--------------------------------------*
 * layout
 *--------------------------------------*/
/* header
--------------------------- */
header {
  width: 100%;
  z-index: 10;
}
header * {
  margin-bottom: 0;
}
header .group-brand .container {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
header .group-brand button {
  font-size: 14px;
  font-size: 1.4rem;
  padding: 0.35em 1.25em 0.25em;
  border: solid 1px #8c8c8c;
  border-radius: 50px;
  background-color: #ffffff;
}
header .group-brand button:hover {
  color: #ffffff;
  background-color: rgba(3, 163, 235, .8);
  border: solid 1px rgba(3, 163, 235, .8);
  -webkit-transition: 1s;
  transition: 1s;
}
header .select-area > li:not(:first-child) {
  margin-left: 15px;
  margin-left: 1.5rem;
}
header .select-accordion {
  line-height: 1;
  margin: 0;
}
header .select-accordion summary {
  width: 200px;
  background-color: #ffffff;
  border: solid 1px #ccc;
  border-radius: 4px;
  z-index: 100;
}
header .select-accordion summary > div {
  padding: 7px 12px;
  -webkit-transition: all 0.4s ease-out;
  transition: all 0.4s ease-out;
}
header .select-accordion summary > span {
  width: 11px;
  height: 11px;
  margin: -6px 10px 0 0;
  border: 2px solid;
  border-color: transparent transparent #03A3EB #03A3EB;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  -webkit-transition: all 0.4s ease-out;
  transition: all 0.4s ease-out;
}
header .select-accordion[open] summary {
  color: #8c8c8c;
  background-color: #efefef;
}
header .select-accordion[open] summary > span {
  margin-top: 4px;
  -webkit-transform: rotate(135deg);
          transform: rotate(135deg);
  -webkit-transition: all 0.4s ease-out;
  transition: all 0.4s ease-out;
}
header .sublist {
  position: relative;
  margin: 0;
  background-color: rgba(255, 255, 255, .95);
  border: solid 1px #ccc;
  border-top: none;
  border-radius: 0 0 4px 4px;
  z-index: 75;
}
header .sublist li {
  line-height: 1;
  border-bottom: dotted 1px #ccc;
  -webkit-transition: all 0.4s ease-out;
  transition: all 0.4s ease-out;
}
header .sublist li a {
  display: block;
  width: 100%;
  text-align: center;
  padding: 1em;
  background-color: rgba(3, 163, 235, .035);
}
header .sublist li a:hover {
  color: #ffffff;
  background-color: #03a3eb;
}
header .sublist li:first-child a {
  padding-top: 1.25em;
}
header .sublist li:last-child {
  border: none;
  border-radius: 0 0 4px 4px;
}
header .school-info .school_name {
  position: relative;
  color: #4c4c4c;
  height: 60px;
  line-height: 1;
  z-index: 1000;
}
header .school-info .school_name img {
  height: 26px;
}
header .school-info .school_name span {
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: normal;
  margin-left: 1em;
  padding: 0.4em 0.6em;
  border: solid 1px #4c4c4c;
  border-radius: 3px;
}
header .school-info .contact li:not(:last-child) {
  margin-right: 1.5em;
}
header .school-info .contact li.phone {
  color: #0E55C3;
  font-size: 28px;
  font-size: 2.8rem;
  font-weight: 500;
  padding-top: 2px;
}
header .school-info .contact li.phone img {
  margin: -2px 0.35em 0 0;
}
header .school-info .contact li img {
  width: 32px;
  height: 32px;
}
/* l-footer
--------------------------- */
footer {
  position: sticky;
  top: 100vh;
  background-color: rgba(239, 239, 239, .6);
}
footer strong {
  color: #ffffff;
}
footer a:link, footer a:visited {
  color: #4c4c4c;
}
footer .container {
  padding: 50px 0 40px;
  padding: 5rem 0 4rem;
}

/**
* ===================================================================
* ▽ 原田が追記・調整したSCSS
* ------------------------------------------------------------------- */
.copyright {
  padding: 1.25em;
  font-size: 13px;
  font-size: 1.3rem;
}
.copyright .text-bold {
  font-weight: 600;
}

.footer-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 100px;
}

.logo-all {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.logo-all .logo-svg {
  height: 25px;
  display: inline-block;
}
.logo-all .linebox {
  font-size: 15px;
  font-size: 1.5rem;
  display: inline-block;
  padding: 0 8px;
  border: 1px solid #0E55C3;
  color: #0E55C3;
}

.group-schools .school-list {
  margin-top: 20px;
}
.group-schools .school-list li {
  font-size: 15px;
  font-size: 1.5rem;
}
.group-schools .school-list li:not(:last-child) {
  margin-bottom: 0.7em;
}
.group-schools .school-list li a {
  position: relative;
  white-space: nowrap;
  margin-left: 2.2em;
}
.group-schools .school-list li a::before {
  position: absolute;
  top: 0;
  left: -1.5em;
  display: inline-block;
  content: "";
  width: 1.15em;
  height: 1.15em;
  padding-left: 1.5em;
  background: url("../img/icon-school.svg") no-repeat center left;
  background-size: contain;
}

.separate-box {
  border-right: 2px dotted #8c8c8c;
  width: 10px;
}

.home-school .common-list li {
  font-size: 15px;
  font-size: 1.5rem;
}
.home-school .common-list li:not(:last-child) {
  margin-bottom: 0.5em;
}
.home-school .common-list li a {
  position: relative;
  white-space: nowrap;
  margin-left: 2.3em;
}
.home-school .common-list li a::before {
  position: absolute;
  top: 0;
  left: -1.5em;
  display: inline-block;
  content: "";
  width: 1em;
  height: 1em;
  padding-left: 1.5em;
  background: url("../img/icon-list.svg") no-repeat center left;
  background-size: contain;
}

.contact-set {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 12px;
  padding-left: 10px;
  margin-top: 15px;
  margin-bottom: 20px;
}
.contact-set .icon-circle {
  height: 30px;
}
.contact-set .phone {
  width: 170px;
}
.contact-set .phone img {
  float: left;
}
.contact-set .phone a:link, .contact-set .phone a:visited {
  color: #0E55C3;
  font-size: 21px !important;
  font-size: 2.1rem !important;
  font-weight: 500 !important;
}
.contact-set .tel-number {
  float: right;
  display: block;
  margin-top: 1px;
}

/**
* ===================================================================
* トップへ戻るボタン
* ------------------------------------------------------------------- */
#page_top {
  position: fixed;
  bottom: 25px;
  right: 25px;
}
#page_top a {
  display: block;
  color: #fff;
  width: 54px;
  height: 54px;
  text-decoration: none;
  background: rgba(14, 85, 195, .9);
  text-align: center;
  border-radius: 50%;
  outline: none;
}
/* グローバルナビゲーション
--------------------------- */
summary {
  display: block;
  list-style: none;
}

summary::-webkit-details-marker {
  display: none;
}
/* c-table
--------------------------- */
.article_content h3 {
  color: #ffffff;
  font-weight: 400;
  font-size: 20px;
  font-size: 2rem;
  min-height: 28px;
  padding-top: 0;
  padding-left: 30px;
  padding-bottom: 2px;
  margin: 70px 5px 30px;
  background: url(/manage/wp-content/themes/design/img/white-diagonal-line.svg) no-repeat top left;
  background-size: 26px;
  outline: 5px solid rgba(3, 163, 235, .6);
  background-color: rgba(3, 163, 235, .6);
}
.article_content h4 {
  position: relative;
  color: #0E55C3;
  font-size: 20px;
  font-size: 2rem;
  font-weight: 500;
  margin: 50px auto 20px;
  margin: 50px auto 2rem;
  padding-left: 36px;
}
.article_content h4:before {
  display: block;
  position: absolute;
  left: 0;
  top: 3px;
  content: " ";
  width: 20px;
  height: 20px;
  background: url(/manage/wp-content/themes/design/img/blue-diagonal-mark.svg) no-repeat;
}
.article_content h5 {
  color: #0E55C3;
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: 500;
  margin: 35px 0 15px;
  margin: 35px 0 1.5rem;
}
.article_content h6 {
  color: #0E55C3;
  font-size: 17px;
  font-size: 1.7rem;
  font-weight: 500;
  margin: 25px 0 15px;
  margin: 25px 0 1.5rem;
}
.article_content ul.wp-block-list {
  list-style-type: disc;
  margin-left: 1.75em;
}
.article_content ol.wp-block-list {
  list-style-type: decimal;
  margin-left: 1.75em;
}
.article_content ol.wp-block-list li::marker {
  color: #5c5c5c;
  font-weight: 600;
}
.article_content .wp-block-image figcaption {
  font-size: 0.9em;
  text-align: center;
}
@media screen and (max-width: 768px) {
  main section {
    padding: 5rem 0;
  }
  table th, table td {
    padding: 1rem 2rem;
  }
  .container, .full-container, .min-container {
    padding-left: 2%;
    padding-right: 2%;
  }
}
@media screen and (max-width: 767px) {
  .tab {
    line-height: 1.4;
    padding: 0.85em 0 0.65em;
  }
  .footer_link {
    margin: auto;
  }
}
@media screen and (max-width: 640px) {
  .panel {
    padding: 25px 15px;
  }
  .fin {
    margin-bottom: 5rem !important;
  }
  .gtranslate_wrapper {
    margin-inline: auto;
  }
  h1, .h01 {
    font-size: 2.4rem;
  }
  h2, .h02 {
    font-size: 2.1rem;
  }
  h3, .h03 {
    font-size: 1.8rem;
  }
  h4, .h04 {
    font-size: 1.6rem;
  }
  h5, .h05 {
    font-size: 1.5rem;
  }
  h6, .h06 {
    font-size: 1.4rem;
  }
  main section {
    padding: 8rem 0;
  }
  header .select-accordion {
    margin-bottom: 1.25em;
  }
  header .group-brand {
    font-size: 1.5rem !important;
    margin-top: 25px;
    padding-top: 25px;
    border-top: solid 1px #ffffff;
  }
  header .group-brand.head {
    display: none;
  }
  header .group-brand > .container {
    max-width: 360px;
    width: 100%;
    margin-inline: auto;
  }
  header .group-brand button {
    font-size: 1.5rem !important;
    display: block;
    margin: 0 auto 20px;
  }
  header .group-brand .select-area {
    width: 100%;
  }
  header .group-brand .select-area li {
    margin: 0 auto;
  }
  header .group-brand .select-accordion summary {
    width: 158px;
  }
  header .group-brand .select-accordion summary > div {
    padding-block: 9px;
  }
  header .school-info {
    padding: 0.2em 2% !important;
  }
  header .school-info .contact {
    display: none;
  }
  body.active {
    height: 100%;
    overflow: hidden;
  }
  .masterNav {
    display: none;
    left: 0;
    position: fixed;
    width: 100%;
    min-height: calc(100vh - 50px);
    height: 100%;
    padding: 40px 35px 200px;
    background-color: #0E55C3;
    border: none;
    overflow-y: scroll;
    z-index: 110;
    -webkit-animation: fadeup 0.75s cubic-bezier(0.33, 1, 0.68, 1) backwards;
            animation: fadeup 0.75s cubic-bezier(0.33, 1, 0.68, 1) backwards;
  }
  .masterNav .container {
    padding: 0;
    margin-bottom: 25px;
  }
  .masterNav .accordion {
    margin-bottom: 4%;
    background-color: #ffffff;
    border-radius: 5px;
  }
  .masterNav .accordion-summary, .masterNav div.accordion {
    color: #0E55C3;
    font-size: 1.8rem;
    font-weight: 500;
    padding: 0.75em 1em;
  }
  .masterNav .accordion-summary {
    display: grid;
    grid-template-columns: auto 1fr;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 1em;
    overflow: hidden;
  }
  .masterNav .accordion-summary::before, .masterNav .accordion-summary::after {
    grid-column: 2;
    grid-row: 1;
    justify-self: end;
    content: "";
    width: 18px;
    border-bottom: 2px solid #5c5c5c;
  }
  .masterNav .accordion-summary::before {
    -webkit-transform: rotate(-90deg);
            transform: rotate(-90deg);
    -webkit-transition: -webkit-transform 0.3s;
    transition: -webkit-transform 0.3s;
    transition: transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s;
  }
  .masterNav details[open] .accordion-summary::before {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  .masterNav details[open] .accordion-summary::after {
    opacity: 0;
    -webkit-animation: fadeout 0.3s cubic-bezier(0.33, 1, 0.68, 1) backwards;
            animation: fadeout 0.3s cubic-bezier(0.33, 1, 0.68, 1) backwards;
  }
  .masterNav.active {
    display: block;
  }
  .sub li {
    font-size: 1.7rem;
    padding: 0.75em 1em 0.75em 1.5em !important;
    background-color: rgba(14, 85, 195, .05);
    border-top: dotted 1px #0E55C3;
  }
  .sub li span:before {
    display: inline-block;
    content: "";
    margin-top: 8px;
    margin-right: 12px;
    width: 6px;
    height: 6px;
    vertical-align: top;
    border-radius: 5px;
    background-color: rgba(60, 60, 60, .75);
  }
  .btnMenu {
    width: 28px;
    height: 30px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .btnMenu span {
    display: inline-block;
    width: 30px;
    height: 2px;
    background-color: #0E55C3;
    position: relative;
    z-index: 100;
  }
  .btnMenu span::before, .btnMenu span::after {
    content: "";
    display: inline-block;
    width: 28px;
    height: 2px;
    background-color: #0E55C3;
    position: absolute;
    left: 0;
    -webkit-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
  }
  .btnMenu span::before {
    top: 9px;
  }
  .btnMenu span::after {
    top: -9px;
  }
  .btnMenu.active {
    padding-top: 6px;
  }
  .btnMenu.active span {
    background-color: transparent;
  }
  .btnMenu.active span::before, .btnMenu.active span::after {
    top: -4px;
  }
  .btnMenu.active span::before {
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
  }
  .btnMenu.active span::after {
    -webkit-transform: rotate(-45deg);
            transform: rotate(-45deg);
  }
  .contact {
    max-width: 200px;
    margin-inline: auto;
  }
  @-webkit-keyframes fadeout {
    0% {
      opacity: 1;
    }
    100% {
      opacity: 0;
    }
  }
  @keyframes fadeout {
    0% {
      opacity: 1;
    }
    100% {
      opacity: 0;
    }
  }
}
@media (max-width: 1024px) {
  p.detailButton {
    font-size: 1.3rem;
  }
}
@media screen and (max-width: 650px) {
  h2.title {
    padding-left: 2.2%;
  }
  h2.title:before {
    left: 48.2%;
  }
  h2.title:after {
    left: calc(48.2% - 5px);
  }
  h2.title-blueback {
    padding-left: 2.2%;
  }
  h2.title-blueback:before {
    left: 48.2%;
  }
  h2.title-blueback:after {
    left: calc(48.2% - 5px);
  }
}
@media screen and (max-width: 500px) {
  h2.title:before {
    left: 46%;
  }
  h2.title:after {
    left: calc(46% - 5px);
  }
  h2.title-blueback:before {
    left: 46%;
  }
  h2.title-blueback:after {
    left: calc(46% - 5px);
  }
}
@media (max-height: 1000px) {
  h1.sectionTitle {
    font-size: 5.8rem;
  }
}
@media screen and (max-width: 1440px) {
  .container, .full-container, .min-container {
    padding-left: 1.5%;
    padding-right: 1.5%;
  }
  h1.sectionTitle {
    font-size: 5.8rem;
  }
  .masterNav > ul > li {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 1280px) {
  .min-container {
    width: 85%;
  }
  body {
    font-size: 1.6rem;
  }
  h1.sectionTitle {
    font-size: 4.6rem;
  }
  footer .container {
    width: 97%;
    margin-inline: auto;
  }
}
@media screen and (max-width: 1024px) {
  body {
    font-size: 1.4rem;
  }
  h1, .h01 {
    font-size: 2.6rem;
  }
  h2, .h02 {
    font-size: 2.4rem;
  }
  h3, .h03 {
    font-size: 2.1rem;
  }
  h4, .h04 {
    font-size: 1.8rem;
  }
  h5, .h05 {
    font-size: 1.6rem;
  }
  h6, .h06 {
    font-size: 1.5rem;
  }
  header .logo {
    width: 100px;
  }
  header .group-brand, header .group-brand button {
    font-size: 1.3rem;
  }
  header .select-accordion summary {
    width: 200px;
  }
  header .school-info .school_name {
    height: 50px;
  }
  header .school-info .school_name span {
    font-size: 1.2rem;
  }
  header .school-info .school_name img {
    height: 24px;
  }
  header .school-info .contact li.phone {
    font-size: 2.1rem;
    padding-top: 2px;
  }
  header .school-info .contact li.phone img {
    margin-top: -2px;
  }
  header .school-info .contact li:not(:last-child) {
    margin-right: 1.25em;
  }
  header .school-info .contact li img {
    width: 30px;
    height: 30px;
  }
  .accordion {
    font-size: 1.4rem;
  }
  .accordion-summary, div.accordion {
    padding-block: 0.84em;
  }
  .sub {
    font-size: 1.3rem;
  }
  .sub li {
    padding-block: 1em;
  }
}
@media screen and (max-width: 480px) {
  h1, .h01 {
    font-size: 2.1rem;
  }
  h2, .h02 {
    font-size: 1.8rem;
  }
  h3, .h03 {
    font-size: 1.6rem;
  }
  h4, .h04 {
    font-size: 1.5rem;
  }
  h5, .h05 {
    font-size: 1.4rem;
  }
  main section {
    padding: 5rem 0;
  }
  header .school-info .school_name {
    height: 52px;
  }
  header .school-info .school_name span {
    font-size: 1rem;
  }
  header .school-info .school_name img {
    width: 150px;
  }
  footer .container {
    padding: 5rem 1.5%;
  }
  .row.schools {
    display: block;
  }
  .row.schools ul {
    display: table;
    margin-inline: auto;
  }
  .row.schools ul.school-list {
    padding-top: 5rem;
  }
  .copyright .text-bold {
    display: block;
  }
  #page_top {
    bottom: 15px;
    right: 15px;
  }
  #page_top a {
    width: 46px;
    height: 46px;
  }
}
@media screen and (max-width: 375px) {
  main section {
    padding: 4rem 0;
  }
  header .school-info .school_name {
    height: 30px;
  }
  header .school-info .school_name span {
    font-size: 0.9rem;
  }
  header .school-info .school_name img {
    width: 150px;
  }
  header .nav {
    padding-inline: 0 !important;
  }
  .group-schools .school-list li {
    font-size: 1.4rem !important;
  }
  .home-school .common-list li {
    font-size: 1.4rem !important;
  }
  .btnMenu {
    width: 26px;
    height: 28px;
  }
  .btnMenu span {
    width: 28px;
  }
  .btnMenu span::before, .btnMenu span::after {
    width: 26px;
  }
  .btnMenu span::before {
    top: 8px;
  }
  .btnMenu span::after {
    top: -8px;
  }
  .masterNav {
    padding: 30px 23px 200px;
  }
  .masterNav .accordion-summary, .masterNav div.accordion {
    font-size: 1.6rem;
  }
  .masterNav .accordion-summary::before, .masterNav .accordion-summary::after {
    width: 16px;
  }
  .sub li {
    font-size: 1.5rem;
  }
  .sub li span:before {
    margin-top: 8px;
    margin-right: 10px;
    width: 5px;
    height: 5px;
  }
}
@media screen and (max-width: 1360px) {
  header .container {
    padding-inline: 1%;
  }
}
@media screen and (min-width: 641px) {
  header .group-brand {
    height: 50px;
    padding-top: 10px;
    margin-bottom: 5px;
    background: -webkit-gradient(linear, left top, left bottom, from(#e7e7e7), to(#FFF));
    background: linear-gradient(to bottom, #e7e7e7, #FFF);
  }
  header .school-info {
    padding-bottom: 15px;
  }
  .btnMenu {
    display: none;
  }
  .nav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .masterNav {
    position: relative;
    height: 54px;
    padding-inline: 0;
    background-color: rgba(14, 85, 195, .75);
    border-bottom: solid 7px #ffffff;
    z-index: 50;
  }
  .masterNav > ul {
    padding-inline: 0;
  }
  .masterNav > ul > li {
    color: #ffffff;
    width: 14.2857142857%;
    font-size: 1.7rem;
    text-align: center;
    padding: 1.25em 0;
    border-right: dotted 1px rgba(255, 255, 255, .75);
  }
  .masterNav .contact, .masterNav .drower {
    display: none;
  }
  .sub {
    color: #4c4c4c;
    width: calc(100% + 2em);
    font-size: 1.4rem;
    margin: 13px -3px 0 -1em;
    background-color: rgba(231, 236, 247, .9);
    border: solid 1px rgba(14, 85, 195, .75);
    border-radius: 5px;
    -webkit-animation: fadeup 0.5s cubic-bezier(0.33, 1, 0.68, 1) backwards;
            animation: fadeup 0.5s cubic-bezier(0.33, 1, 0.68, 1) backwards;
  }
  .sub li {
    white-space: nowrap;
    padding: 0.9em 0.35em;
    border-bottom: dotted 1px rgba(14, 85, 195, .5);
  }
  .sub li:first-child:before {
    content: "";
    position: absolute;
    top: -25px;
    left: 50%;
    margin-left: -16px;
    border: 13px solid transparent;
    border-bottom: 13px solid #e9eef8;
    z-index: 52;
  }
  .sub li:first-child:after {
    content: "";
    position: absolute;
    top: -27px;
    left: 50%;
    margin-left: -17px;
    border: 14px solid transparent;
    border-bottom: 14px solid rgba(14, 85, 195, .75);
    z-index: 51;
  }
  .sub li:last-child {
    border: none;
  }
  .sub li:hover {
    color: #ffffff;
    background-color: #0e55c3;
    opacity: 1;
    cursor: pointer !important;
  }
  .accordion {
    position: static;
    color: #ffffff;
    width: 20%;
    font-size: 1.5rem;
    text-align: center;
    z-index: 50;
  }
  .accordion.linkbox {
    position: relative;
  }
  .accordion:hover {
    cursor: pointer;
  }
  .accordion .first {
    border-left: dotted 1px rgba(255, 255, 255, .75);
  }
  .accordion-summary, div.accordion {
    height: 54px;
    line-height: 1;
    padding: 0 0.5em;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    cursor: pointer !important;
    border-right: dotted 1px rgba(255, 255, 255, .75);
  }
  .accordion-summary:hover, div.accordion:hover {
    cursor: pointer;
    background-color: #0E55C3;
    opacity: 1;
  }
  @-webkit-keyframes fadeup {
    0% {
      -webkit-transform: translateY(15px);
              transform: translateY(15px);
      opacity: 0;
    }
    80% {
      opacity: 1;
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
  }
  @keyframes fadeup {
    0% {
      -webkit-transform: translateY(15px);
              transform: translateY(15px);
      opacity: 0;
    }
    80% {
      opacity: 1;
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
  }
}
@media screen and (max-width: 374px) {
  header .school-info .school_name {
    height: 50px;
  }
  header .school-info .school_name span {
    font-size: 0.8rem;
  }
  header .school-info .school_name img {
    width: 150px;
  }
  header .group-brand .select-area {
    width: 100%;
  }
  header .group-brand .select-area > li {
    margin: 0 auto 20px !important;
  }
  header .group-brand .select-accordion summary {
    width: 170px;
  }
}
@media screen and (min-width: 801px) and (max-width: 1079px) {
  .footer-flex {
    gap: 50px;
  }
}
@media screen and (max-width: 800px) {
  .footer-flex {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 30px;
  }
  .group-schools .school-list li {
    font-size: 1.5rem;
  }
  .home-school .common-list li {
    font-size: 1.5rem;
  }
}
@media screen and (max-width: 1000px) {
  .logo-all .logo-svg {
    height: 20px;
    padding-bottom: 2px;
  }
  .logo-all .linebox {
    font-size: 1.2rem;
  }
}
@media screen and (min-width: 481px) {
  .copyright .text-bold {
    margin-right: 0.35em;
  }
}
@media screen and (min-width: 1361px) {
  .masterNav .container {
    padding-inline: 0;
  }
}
@media screen and (max-width: 1336px) {
  .masterNav > ul {
    padding-inline: 0.75%;
  }
}
@media screen and (min-width: 1025px) {
  .masterNav {
    height: 60px;
  }
  .accordion {
    font-size: 1.7rem;
  }
  .accordion-summary, div.accordion {
    height: 54px;
    line-height: 1;
    padding: 0 0.5em;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .sub {
    font-size: 1.6rem;
    line-height: 1;
    margin: 13px -3px 0 -1em;
  }
  .sub li {
    padding: 0.9em 0.35em;
  }
  .sub li:first-child:before {
    top: -25px;
    left: 50%;
    margin-left: -16px;
  }
  .sub li:first-child:after {
    top: -27px;
    left: 50%;
    margin-left: -17px;
  }
  .sub li font font {
    white-space: normal;
  }
}
/*# sourceMappingURL=maps/common.css.map */
