@charset "utf-8";

/*  link
================================================== */
a {
  color: #1874cd;
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

a:visited {
  color: #634aac;
}

/* Fonts
================================================== */

html {
  font-size: 62.5%;
}

@media print {
  html {
    font-size: 38%;
  }
}

/* 10px base */
body {
  -webkit-text-size-adjust: 100%;
  overscroll-behavior-y: none;
  word-wrap: break-word;
  overflow-wrap: break-word;
  font-family: "ヒラギノ⾓ゴProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  line-height: 1.5;
  color: #333;
  font-size: 1.4rem;
  text-align: left;
  overflow-x: hidden;
  padding-bottom: 40px;
  position: relative;
  min-height: 100vh;
}

@media only screen and (max-width: 768px) {

  body {
    font-size: 1.2rem;
  }
}

input,
button,
textarea,
select {
  font-family: "ヒラギノ⾓ゴProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  line-height: 1.5;
  color: #333;
}

[role=tabpanel][aria-hidden=true] {
  display: none;
}

[role=tabpanel][aria-hidden=false] {
  display: block;
}
@media print {
  .print-page-break{
    page-break-before: always;
}
}
/* material-icon
================================================== */
.ma-icon {
  font-style: normal;
  vertical-align: middle;
}

/*  */
.pc-only {
  display: block;

}

.sp-only {
  display: none;

}

@media only screen and (max-width: 768px) {
  .pc-only {
    display: none;
  }

  .sp-only {
    display: block;

  }
}

/* Flex
================================================== */
.flex {
  display: -webkit-flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

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

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

.align-items_start {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}

.align-items_baseline {
-webkit-box-align: baseline;
-ms-flex-align: baseline;
align-items: baseline;
}
.align-items_end {
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}

.justify-content_end {
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}

.justify-content_start {
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}

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

.flex-wrap-wrap {
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
@media only screen and (max-width: 768px) {
  
.sp_justify-content_space-between {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

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

.sp_align-items_start {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}

.sp_align-items_end {
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}

.sp_justify-content_end {
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}

.sp_justify-content_start {
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}

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

.sp_flex-wrap-wrap {
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.sp_flex-direction_row-reverse {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}
.sp_flex-direction_column-reverse{  	-webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
}
}

/* Btn
================================================== */
.btn-border {
  border: 1px solid #b3000f;
  border-radius: 4px;
  padding: 0.5rem 1rem;
  display: inline-block;
}

.btn-border:hover {
  background: #b3000f;
  text-decoration: none;
}

.btn-bg {
  background: #b3000f;
  color: #ffffff;
  border-radius: 4px;
  padding: 0.5rem 1rem;
  display: inline-block;
}

.btn-bg:visited {
  color: #ffffff;
}

.btn-bg:hover {
  opacity: 0.8;
  text-decoration: none;
}

.btn-bg._small {
  padding: 0.3rem 0.5rem;
  min-width: 3em;
  font-size: 1.2rem;
  text-align: center;

}
.btn-bg._big{
  padding: 1rem 2rem 1rem 2rem;
  min-width: 15rem;
  text-align: center;
}
.btn-bg._arrow{
  position: relative;
  padding: 1rem 3rem 1rem 2rem;
}
.btn-bg._arrow::after{
  content: "\e409";
	font-family: 'Material Icons Outlined';
	vertical-align: middle;
	line-height: 1;
	font-size: 2rem;
  color: #ffffff;
  position: absolute;  
  right: 0.5rem;
  top: 0;
  bottom: 0;
  margin: auto;
  display: inline-block;
  height: 1em;
}
.btn-bg._small._arrow{
  padding: 0.5rem 2.5rem 0.5rem 1.5rem;
}
.btn-bg._small._arrow::after{
  right: 0.3rem;
}
.btn-bg._cancel{
  background: #999999;
  color: #ffffff;
  border: 1px solid #999999;
}
.btn-bg._default {
  background: #f5f5f5;
  color: #333333;
  border: 1px solid #aaaaaa;
}

.btn-bg._default:visited {
  color: #000;
}

.btn-bg.primary {

  color: #ffffff;
  background: #ff9800;
  border: 1px solid #ff9800;
}

.btn-bg.secondary {
  color: #fff;
  background: #690;
  border: 1px solid #690;
}
.btn-bg._alreadyRead{
  color: #fff;
  background: #b1b100;
  border: 1px solid #b1b100;
}
.bth-arrow {
  padding-right: 2.5rem;
  position: relative;
}

.bth-arrow::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0.5rem;
  margin: auto;
  width: 0.8rem;
  height: 0.8rem;
  border-top: 1px solid #ffffff;
  border-right: 1px solid #ffffff;
  -webkit-transform: translateX(-50%) rotate(45deg);
  transform: translateX(-50%) rotate(45deg);
}
.btn-bg._disabled{
  background: #f0f0f0;
  opacity: 0.7;
  cursor: default;
  border: 1px solid #ccc;
  color: #999;
  pointer-events: none;
}
/* Btn-Subject
================================================== */
.btn-border.btn-kokugo {
  border: 1px solid #c53636;
  color: #c53636;
}

.btn-border.btn-kokugo:hover {
  background: #c53636 !important;
  color: #ffffff;
}

.btn-border.btn-sansu {
  border: 1px solid #534296;
  color: #534296;
}

.btn-border.btn-sansu:hover {
  background: #534296 !important;
  color: #ffffff;
}

.btn-border.btn-shakai {
  border: 1px solid #e17b00;
  color: #e17b00;
}

.btn-border.btn-shakai:hover {
  background: #e17b00 !important;
  color: #ffffff;
}

.btn-border.btn-rika {
  border: 1px solid #467746;
  color: #467746;
}

.btn-border.btn-rika:hover {
  background: #467746 !important;
  color: #ffffff;
}

.btn-border.btn-keisan {
  border: 1px solid #1e4491;
  color: #1e4491;
}

.btn-border.btn-keisan:hover {
  background: #1e4491 !important;
  color: #ffffff;
}


.btn-bg.btn-kokugo {
  background: #c53636;
}

.btn-bg.btn-sansu {
  background: #534296;
}

.btn-bg.btn-shakai {
  background: #e17b00;
}

.btn-bg.btn-rika {
  background: #467746;
}
.btn-bg.btn-keisan {
  background: #1e4491;
}

/* color
================================================== */
.color-red {
  color: #e60012 !important;
}
.color-blue{
  color: #0033cc!important;
  
}
.color-orange{
  color: #ff9800 !important;

}
/* Subject
================================================== */
.color-kokugo {
  color: #c53636 !important;
}

.color-sansu {
  color: #534296 !important;
}

.color-shakai {
  color: #e17b00 !important;
}

.color-rika {
  color: #467746 !important;
}

.color-error {
  color: #e60012 !important;
}
.color-boysSchool{
  color:  #3198cc!important;
}
.color-girlsSchool{
  color:  #c92b2b!important;
}
.color-coSchool{
  color:  #56a956!important;
}
.bg-boysSchool{
  background-color:  #3198cc!important;
}
.bg-girlsSchool{
  background-color:  #c92b2b!important;
}
.bg-coSchool{
  background-color:  #56a956!important;
}
.bg-kokugo {
  background-color: #c53636 !important;
}

.bg-sansu {
  background-color: #534296 !important;
}

.bg-shakai {
  background-color: #e17b00 !important;
}

.bg-rika {
  background-color: #467746 !important;
}

.bg-kokugo-2 {
  background-color: #EDC2C2 !important;
}

.bg-sansu-2 {
  background-color: #CBC6DF !important;
}

.bg-shakai-2 {
  background-color: #F6D7B2 !important;
}

.bg-rika-2 {
  background-color: #C7D6C7 !important;
}

.bg-subj-four-2 {
  background-color: #f6d4d8 !important;
}

.bg-subj-three-2 {
  background-color: #c6eddb !important;
}

.bg-subj-two-2 {
  background-color: #d5e0f1 !important;
}

.border-color-kokugo {
  border-color: #c53636 !important;
}

.border-color-sansu {
  border-color: #534296 !important;
}

.border-color-shakai {
  border-color: #e17b00 !important;
}

.border-color-rika {
  border-color: #467746 !important;
}

.border-color-subj-four {
  border-color: #c7243a !important;
}

.border-color-subj-three {
  border-color: #009250 !important;
}

.border-color-subj-two {
  border-color: #3261ab !important;
}
.system-error-text{
	font-size: 1.4rem;
  color: #333333;

}
.user-error-text{
	font-size: 1.4rem;
  color: #e60012;
}

@media screen and (max-width:768px) {
  .system-error-text, .user-error-text{
    font-size: 1.2rem;
  }
}
/* Header
================================================== */

.site-header {
  background-color: #e60012;
  padding: 1rem;
}

.site-logo {
  max-width: 80%;
}

.site-logo a {
  color: #ffffff;
  font-size: 1.2rem;
}

.site-logo a:hover {
  text-decoration: none;
}

.site-logo a:visited {
  color: #ffffff;
}

.logo-symbol {
  margin-right: 1rem;
  width: 38px;
  height: 51px;
}

.logo-txt {
  width: 220px;
  height: 24px;
}

@media screen and (max-width:768px) {

  .logo-symbol {}

  .logo-textBox {
    max-width: calc(100% - 48px);
    width: auto;
  }

  .logo-txt {
    max-width: 100%;
  }
}

.subUiArea {
  position: relative;
  display: inline-block;
}

.personInfo {
  background: #fdf8db;
  color: #000;
  text-decoration: none;
  -webkit-border-radius: 100px;
  -moz-border-radius: 100px;
  border-radius: 100px;
  padding: 3px 8px 2px;
  padding-right: 25px;
  cursor: pointer;
  position: relative;
}

.personInfo:before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border: 5px solid transparent;
  border-top: 5px solid #000;
  position: absolute;
  top: 50%;
  right: 10px;
  margin-top: -3px;
  transition: all 0.2s ease-in-out;
}

@media screen and (max-width:768px) {
  .site-subMenu {
    width: 100%;
    text-align: right;
    margin-top: 1rem;
  }

  .personInfo {
    display: inline-block;
  }

}

@media print {

  .logo-symbol {
    width: 28px;
    height: 41px;
  }

  .site-subMenu {
    max-width: 75%;
  }

  .site-logo {
    width: 24%;
  }

  .logo-textBox {
    max-width: calc(100% - 41px);
    width: auto;
  }

  .logo-textBox img {
    max-width: 100%;
    height: auto;
  }

}

.personInfo-menu {
  display: none;
  background-color: #ffffff;
  -webkit-border-radius: 4px;
  -moz-border-radius: 4px;
  border-radius: 4px;
  text-align: left;
  padding: 0;
  position: absolute;
  top: 35px;
  right: 0px;
  left: 0;
  -webkit-box-shadow: 0 3px 12px 0px rgb(28 31 41 / 36%);
  -moz-box-shadow: 0 3px 12px 0px rgba(28, 31, 41, 0.36);
  box-shadow: 0 3px 12px 0px rgb(28 31 41 / 36%);
  min-width: 120px;
  z-index: 100;
}

@media screen and (max-width:1180px) {

  .personInfo-menu {
    top: 25px;
  }
}

.personInfo-menu li:first-child a {
  border-radius: 4px 4px 0 0;
}

.personInfo-menu li:last-child a {
  border-radius: 0 0 4px 4px;
}

.personInfo-menu a {
  padding: 0.5rem 1rem;
  display: block;
  color: #333;
}

.personInfo-menu a:hover {
  background-color: #ffecec;
  color: #333;
  text-decoration: none;
}

/* ===== 職員用 ===== */

@media print,
screen and (min-width:768px) {
  .site-subMenu_item {
    color: #ffffff;
    font-size: 1.2rem;
    margin-right: 2rem;
  }

  .site-subMenu_item:last-child {
    margin-right: 0;
  }

  .site-subMenu_item .modeInfo a {
    color: #fff;
  }

  .site-subMenu_item input[type="text"] {
    border: 1px solid #ccc;
    border-radius: 4px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    padding: 9px;
    font-size: 1.3rem;
    margin: 0;
    background-color: #ffffff;
    margin-right: 5px;
    /* width: 60%; */
    width: calc(100% - 3em - 6rem);
  }

  .settingDateAndTime {
    border: 1px dotted #333;
    background-color: rgba(255, 255, 255, 0.8);
    color: #333;
    padding: 4px 5px 4px 4px;
    height: auto;
    font-size: 1.1rem;
  }

  .settingDateAndTime p span {
    font-weight: bold;
    margin: 1px 2px 1px 0;
    padding: 0 2px 2px 0;
    border-bottom: 1px solid #000;
  }
}

@media print {
  .site-subMenu_item input[type="text"] {
    width: calc(100% - 6em - 6rem);
  }

}

@media screen and (max-width:1200px) {
  .site-subMenu {
    width: 100%;
    display: -webkit-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
  }
}

@media screen and (max-width:768px) {
  .sp-site-subMenu_cont {
    padding: 1rem;
    background-color: #e60012;
    width: calc(100% - 2rem);
    margin: 2rem auto 0;
  }

  .sp-site-subMenu_item {
    color: #ffffff;
    font-size: 1.2rem;
    padding-bottom: 1rem;
    width: 80%;
    margin: auto;
  }

  .sp-site-subMenu_item .modeInfo a {
    color: #fff;
    text-align: center;
    display: block;
  }

  .sp-site-subMenu_item input[type="text"] {
    border: 1px solid #ccc;
    border-radius: 4px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    padding: 9px;
    font-size: 1.3rem;
    margin: 0;
    background-color: #ffffff;
    margin-right: 5px;
    text-align: left;
    width: calc(100% - 3em - 6rem);
    font-size: 1.6rem;
    transform: scale(calc(13 / 16));
  }

  .sp-site-subMenu_item .settingDateAndTime {
    border: 1px dotted #333;
    background-color: rgba(255, 255, 255, 0.8);
    color: #333;
    padding: 4px 5px 4px 4px;
    height: auto;
    font-size: 1.1rem;
    text-align: center;
  }

  .sp-site-subMenu_item .settingDateAndTime p span {
    font-weight: bold;
    margin: 1px 2px 1px 0;
    padding: 0 2px 2px 0;
    border-bottom: 1px solid #000;
  }

  .xdsoft_datetimepicker {
    left: auto !important;
    right: 0 !important;
  }
}

/* =====  ===== */
.pc-gnav {
  background-color: #e0e0e0;
}

.pc-gnav ul {
  max-width: 1180px;
  width: 100%;
  margin: auto;
  padding-left: 2rem;
  padding-right: 2rem;
  text-align: center;
}

@media screen and (max-width:1180px) {
  .pc-gnav li {
    max-width: calc(100% / 7);
  }
}

.pc-gnav li a {
  display: -webkit-flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  padding: 1.5rem;
  color: #333;
  font-size: 1.6rem;
  font-weight: bold;
}

.gnav-active {
  background-color: #ffecec;
  color: #333;
  text-decoration: none;
}

.pc-gnav li a:hover {
  background-color: #ffecec;
  color: #333;
  text-decoration: none;
}

.pc-gnav li a:visited {
  color: #333;
}

.pc-gnav li .ma-icon {
  margin-right: 0.5rem;
  font-size: 1.7em;
}

/* icon */
.pc-gnav .ma-e02f {
  color: #f5568b;
}

.pc-gnav .ma-e22b {
  color: #00618c;
}

.pc-gnav .ma-ea40 {
  color: #b1b100;
}

.pc-gnav .ma-e4fb {
  color: #df8200;
}

.pc-gnav .ma-e88e {
  color: #1aae6b;
}

.pc-gnav .ma-f009 {
  color: #30adc4;
}

.pc-gnav .ma-f233 {
  color: #e34f4f;
}

/* ===== grayout ===== */
.pc-gnav li.gray_out a {
  color: #999999;
  pointer-events: none;
}

.pc-gnav .gray_out i {
  color: #999999;
}


/*===== drawer =====*/

@media screen and (max-width:768px) {
  .drawer-nav {
    color: #ffffff;
    background-color: #3c3c3c;
    z-index: 1000;
    width: 50%;
  }

  .drawer--right .drawer-nav {
    right: -50%;
    opacity: 0;
  }

  .drawer--right.drawer-open .drawer-hamburger {
    right: 50%;
  }

  .drawer-brand {
    color: #222;
  }

  .drawer-menu {
    color: #222;
    background-color: #fdf8db;
    z-index: 200;
  }

  .drawer-menu-item {
    padding: 1rem 1rem;
    text-decoration: none;
    color: #222;
    border-bottom: 1px solid #dcdcdc;
    font-size: 1.2rem;
  }

  .drawer-menu-item:visited {
    color: #222;
  }

  .drawer-menu-item:hover {
    text-decoration: none;
    font-weight: 500;
    background-color: #cccccc;
    color: #ffffff;
  }

  .drawer-overlay {
    background-color: rgba(0, 0, 0, .6);
  }

  .drawer-open .drawer-overlay {
    display: block;
    z-index: 999;
  }

  .drawer-hamburger {
    background-color: #aaaaaa;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
    width: 30px;
    height: 30px;
    margin: 8px;
    padding: 8px;
    z-index: 1000;
  }

  .drawer-hamburger:hover {
    background-color: #aaaaaa;
  }

  .drawer-hamburger-icon {
    margin-top: 0px;
  }

  .drawer-hamburger-icon,
  .drawer-hamburger-icon:after,
  .drawer-hamburger-icon:before {
    height: 4px;
    background-color: #ffffff;
  }

  .drawer-navbar {
    z-index: 5;
    top: 0;
    width: 100%
  }

  .drawer-dropdown-menu-item {
    cursor: pointer;
    font-size: 1.2rem;
  }

  li a.drawer-dropdown-menu-item {
    width: 100%;
    border-bottom: #dcdcdc 1px dotted;
    vertical-align: baseline;
  }

  li:last-child a.drawer-dropdown-menu-item {
    width: 100%;
    border-bottom: #dcdcdc 1px solid;
  }

  ul.drawer-menu li.drawer-dropdown.open a.drawer-menu-item {
    vertical-align: baseline;
  }

  .drawer--right.drawer-open .drawer-nav,
  .drawer--right .drawer-hamburger,
  .drawer--right.drawer-open .drawer-navbar .drawer-hamburger {
    right: 0;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
    opacity: 1;
  }

  .OtherThanSp-ul-drawer-menu-item {
    margin-bottom: 1rem;
  }

  .drawer-dropdown-menu {
    display: block;
  }

  .drawer-dropdown .open {
    border-bottom: 1px solid #dcdcdc;
  }

  .drawer-menu-item,
  .drawer-dropdown-menu-item {
    padding-top: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid #dcdcdc;
    line-height: 1.4;
  }

  .drawer-dropdown-menu-item {
    padding: 1rem 1.1rem;
  }

  /* icon */
  .drawer-nav i {
    margin-right: 0.5rem;
    width: 1em;
    text-align: center;
  }


  /* icon */
  .drawer-nav .ma-e02f {
    color: #f5568b;
  }

  .drawer-nav .ma-e22b {
    color: #00618c;
  }

  .drawer-nav .ma-ea40 {
    color: #b1b100;
  }

  .drawer-nav .ma-e4fb {
    color: #df8200;
  }

  .drawer-nav .ma-e88e {
    color: #1aae6b;
  }

  .drawer-nav .ma-f009 {
    color: #30adc4;
  }

  .drawer-nav .ma-f233 {
    color: #e34f4f;
  }

  .drawer-nav .ma-e8cd {
    color: #9a5bb4;
  }

  /* ===== grayout ===== */
  .drawer-nav li.gray_out a {
    color: #999999;
    pointer-events: none;
    background-color: #e0e0e0;
  }

  .drawer-nav .gray_out i {
    color: #999999;
  }

}


/* Footer
================================================== */
.site-footer {
  background-color: #888888;
  color: #ffffff;
  text-align: center;
  padding: 0.5rem;
  position: absolute;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 100%;
}

.site-footer small {
  font-size: 1.6rem;
}

