@charset "UTF-8";
body.login {
  /*【ログイン】*/
}
body.login header, body.login .hamburger, body.login footer {
  display: none;
}
body.login .flex {
  height: 100vh;
}
body.login .flex__form {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 782px;
          flex: 1 1 782px;
  /*background: url(../img/login_background.png) center center/cover;*/
  background: #04a1f4;
  padding: 120px 80px;
}
@media screen and (max-width: 768px) {
  body.login .flex__form {
    padding: calc(100vw / 375 * 120 / 1.618) calc(100vw / 375 * 80 / 1.618);
  }
}
@media screen and (max-width: 768px) {
  body.login .flex__form {
    padding: 24px;
  }
}
body.login .flex__form h1 {
  font-size: 32px;
  font-weight: 500;
  margin: auto auto 40px auto;
  color :#ffffff;
}
@media screen and (max-width: 768px) {
  body.login .flex__form h1 {
    font-size: calc(100vw / 375 * 32 / 1.618 );
  }
}
@media screen and (max-width: 379.21875px) {
  body.login .flex__form h1 {
    font-size: 20px;
  }
}
@media screen and (max-width: 768px) {
  body.login .flex__form h1 {
    margin: auto auto calc(100vw / 375 * 40 / 1.618) auto;
  }
}
@media screen and (max-width: 768px) {
  body.login .flex__form h1 {
    margin-bottom: 24px;
  }
}
body.login .flex__form form {
  padding: 40px;
  border-radius: 24px;
  text-align: center;
  margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
  body.login .flex__form form {
    padding: calc(100vw / 375 * 40 / 1.618);
  }
}
@media screen and (max-width: 768px) {
  body.login .flex__form form {
    padding: 24px;
    border-radius: 16px;
  }
}
body.login .flex__form form .form__logo {
  display: block;
  margin: 0px auto 24px auto;
}
body.login .flex__form form .input--singleline {
  margin: 0px auto 32px auto;
  width: 100%;
}
@media screen and (max-width: 768px) {
  body.login .flex__form form .input--singleline {
    margin: calc(100vw / 375 * 0 / 1.618) auto calc(100vw / 375 * 32 / 1.618) auto;
  }
}
body.login .flex__form form .button {
  margin: auto;
}
body.login .flex__form form a {
  margin: 32px auto;
  display: inline-block;
}
@media screen and (max-width: 768px) {
  body.login .flex__form form a {
    margin: calc(100vw / 375 * 32 / 1.618) auto;
  }
}
body.login .flex__logo {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 584px;
          flex: 1 1 584px;
  padding: 120px 56px;
}
@media screen and (max-width: 768px) {
  body.login .flex__logo {
    padding: calc(100vw / 375 * 120 / 1.618) calc(100vw / 375 * 56 / 1.618);
  }
}
body.login .flex__logo img {
  max-width: 100%;
  display: block;
  margin: auto;
}
@media screen and (max-width: 768px) {
  body.login .flex__logo {
    display: none;
  }
}

body {
  background-color: #F8F8F8;
  /*【ヘッダー】*/
}
body aside {
  /*【左メニュー】*/
  background: #fff;
  top: 64px;
  width: 184px;
  left: 0px;
  position: absolute;
  height: calc(100vh - 64px);
  padding-top: 48px;
  -webkit-transition: 0.2s ease;
  transition: 0.2s ease;
}
body aside:not(.active) {
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
}
@media screen and (max-width: 920px) {
  body aside {
    display: none;
  }
}
body aside .aside__button {
  background: #fff;
  width: 32px;
  height: 32px;
  border-radius: 0px 4px 4px 0px;
  position: absolute;
  right: 0px;
  top: 8px;
  -webkit-transform: translateX(100%);
          transform: translateX(100%);
}
body aside .aside__button:after {
  content: "";
  width: 10px;
  height: 10px;
  border-top: 2px solid #202424;
  border-right: 2px solid #202424;
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(-135deg);
          transform: translate(-50%, -50%) rotate(-135deg);
  -webkit-transition: 0.2s ease;
  transition: 0.2s ease;
}
body aside .aside__button:not(.active) {
  background-color: #04a1f4;
}
body aside .aside__button:not(.active):after {
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
          transform: translate(-50%, -50%) rotate(45deg);
  border-color: #fff;
}
body aside nav a {
  display: block;
  padding: 8px 8px 8px 64px;
  margin: 0px 0px 0px auto;
  background-position: left 40px center;
  background-size: 16px auto;
  background-repeat: no-repeat;
  font-size: 15px;
}
body aside nav a.aside__ppt {
  background-image: url(../img/icon_ppt.svg);
}
body aside nav a.aside__setting {
  background-image: url(../img/icon_setting.svg);
}
body header {
  background: #fff;
  border-bottom: 1px solid #EBECEC;
  z-index: 100;
}
body header .header__inner {
  position: relative;
  height: 100%;
  width: 100%;
}
body header .header__inner .header__logo {
  display: inline-block;
  position: absolute;
  left: 40px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  font-size: 15px;
}
@media screen and (max-width: 920px) {
  body header .header__inner .header__logo {
    left: 64px;
  }
}
body header .header__inner nav {
  position: absolute;
  right: 40px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  color: #717777;
  font-size: 15px;
}
@media screen and (max-width: 920px) {
  body header .header__inner nav {
    display: none;
  }
}
body main {
  padding-left: 184px;
  -webkit-transition: 0.2s ease;
  transition: 0.2s ease;
}
body main:not(.active) {
  padding-left: 0px;
}
@media screen and (max-width: 920px) {
  body main {
    padding-left: 0px;
  }
}
body main section {
  padding: 48px 16px 16px 48px;
}
@media screen and (max-width: 920px) {
  body main section {
    padding: 16px;
  }
}

/*【レポート一覧】
body.ppt .aside__ppt {
  background-color: #F8F8F8;
}*/
body.ppt .container {
  max-width: 800px;
}
body.ppt .container .main__header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-bottom: 16px;
}
body.ppt .container .main__header .header__child {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
body.ppt .container .main__header .header__child--right {
  text-align: right;
  white-space: nowrap;
}
body.ppt .container .main__header .button {
  width: 100%;
  max-width: 200px;
}
body.ppt .container .main__header select {
  vertical-align: bottom;
  margin: 0px 4px;
  max-width: 136px;
  background-color: #fff;
}
body.ppt .container .main__body {
  background: #fff;
  padding: 56px 80px 32px 80px;
  border-radius: 24px;
  /*
  .prev:before,
  .next:before{
  	content:'';
  	width:6px;
  	height:6px;
  	border-top:2px solid #202424;
  	border-right:2px solid #202424;
  	position:absolute;
  	right:50%;
  	top:50%;
  	transform:translate(50%, -50%) rotate(45deg);
  }
  .prev:before{
  	transform:translate(50%, -50%) rotate(-135deg);
  }
  */
}
@media screen and (max-width: 768px) {
  body.ppt .container .main__body {
    padding: calc(100vw / 375 * 56 / 1.618) calc(100vw / 375 * 80 / 1.618) calc(100vw / 375 * 32 / 1.618) calc(100vw / 375 * 80 / 1.618);
  }
}
@media screen and (max-width: 768px) {
  body.ppt .container .main__body {
    padding: 16px;
    margin-left: -16px;
    margin-right: -16px;
    border-radius: 0;
  }
}
body.ppt .container .main__body .dataTables_length {
  margin-bottom: 8px;
}
@media screen and (max-width: 640px) {
  body.ppt .container .main__body .dataTables_length label {
    text-align: left;
    display: block;
  }
}
@media screen and (max-width: 640px) {
  body.ppt .container .main__body #list_dt_filter {
    display: block;
    text-align: left;
  }
  body.ppt .container .main__body #list_dt_filter input {
    width: calc(100vw - 16px - 3.5em);
  }
}
body.ppt .container .main__body .search {
  margin-bottom: 16px;
}
body.ppt .container .main__body .search .search__icon {
  display: inline-block;
  vertical-align: middle;
  margin-right: 8px;
}
body.ppt .container .main__body .search .input {
  width: calc(100% - 30px);
}
body.ppt .container .main__body .download {
  margin-bottom: 16px;
}
body.ppt .container .main__body .download select {
  background: #fff;
  margin-right: 8px;
  margin-bottom: 8px;
}
body.ppt .container .main__body .count {
  font-size: 14px;
  color: #717777;
  margin-bottom: 16px;
}
body.ppt .container .main__body .dataTables_wrapper .dataTables_paginate .paginate_button, body.ppt .container .main__body .dataTables_wrapper .dataTables_paginate .ellipsis {
  color: #04a1f4 !important;
}
body.ppt .container .main__body .dataTables_wrapper .dataTables_paginate .paginate_button.current, body.ppt .container .main__body .dataTables_wrapper .dataTables_paginate .ellipsis.current {
  background: #fff;
  border-color: #04a1f4 !important;
}
body.ppt .container .main__body .dataTables_wrapper .dataTables_paginate select {
  background: #fff;
  margin: 8px;
  border: 1px solid #EBECEC;
  font-size: 16px;
  padding: 13px;
  border-radius: 4px;
  text-align: left;
  display: inline-block;
}
body.ppt .container .main__body .prev, body.ppt .container .main__body .next {
  position: relative;
  height: 32px;
  width: 16px;
}
body.ppt .container .main__body .pagenation {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 4px;
  margin: 24px auto 0px auto;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
body.ppt .container .main__body .pagenation .number, body.ppt .container .main__body .pagenation .dots {
  color: #04a1f4;
  font-size: 14px;
  text-align: center;
  border: 1px solid #04a1f4;
  width: 32px;
  height: 32px;
  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;
  border-radius: 4px;
}
body.ppt .container .main__body .pagenation .dots {
  border: none;
}
body.ppt .container .main__body table {
  font-size: 14px;
  width: 100%;
}
body.ppt .container .main__body table input[type=checkbox] {
  width: 17px;
  height: 17px;
}
body.ppt .container .main__body table .list__minitable {
  margin-bottom: 8px;
}
body.ppt .container .main__body table .list__minitable tr:nth-of-type(n) {
  border: none;
}
body.ppt .container .main__body table .list__minitable tr:nth-of-type(n) td {
  text-align: left;
}
body.ppt .container .main__body table .list__buttons {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 8px;
}
body.ppt .container .main__body table .list__buttons a.icon {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  position: relative;
  border: 1px solid #95A5A5;
  -webkit-box-shadow: none;
          box-shadow: none;
}
body.ppt .container .main__body table .list__buttons a.icon img {
  position: absolute;
  left: 8px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  body.ppt .container .main__body table thead {
    /*display: none;*/
  }
}
body.ppt .container .main__body table tr {
  border-bottom: 1px solid #95A5A5;
}
@media screen and (max-width: 768px) {
  body.ppt .container .main__body table tr:nth-of-type(1) {
    border-top: 1px solid #95A5A5;
  }
}
body.ppt .container .main__body table tr.active {
  background: rgba(0, 206, 205, 0.27);
}
body.ppt .container .main__body table tr th {
  background-color: #F8F8F8;
  border: 2px solid #fff;
  font-weight: normal;
  text-align: center;
  padding: 4px;
  vertical-align: middle;
}
body.ppt .container .main__body table tr td {
  padding: 8px 8px;
  vertical-align: middle;
}
body.ppt .container .main__body table tr td:nth-of-type(1) {
  text-align: center;
}
@media screen and (max-width: 768px) {
  body.ppt .container .main__body table tr td:nth-of-type(1) {
    vertical-align: top;
  }
}
body.ppt .container .main__body table tr td .icon {
  width: 40px;
  height: 40px;
  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;
  background: #fff;
  width: 40px;
  -webkit-box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
          box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
  border-radius: 4px;
}

h2 {
  font-size: 32px;
  margin: 0px 0px 40px 0px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  h2 {
    font-size: calc(100vw / 375 * 32 / 1.618 );
  }
}
@media screen and (max-width: 379.21875px) {
  h2 {
    font-size: 20px;
  }
}
@media screen and (max-width: 768px) {
  h2 {
    margin: calc(100vw / 375 * 0 / 1.618) calc(100vw / 375 * 0 / 1.618) calc(100vw / 375 * 40 / 1.618) calc(100vw / 375 * 0 / 1.618);
  }
}

/*【マイページ】*/
.setting form {
  background: #fff;
  padding: 80px;
  border-radius: 24px;
  max-width: 800px;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .setting form {
    padding: calc(100vw / 375 * 80 / 1.618);
  }
}
@media screen and (max-width: 768px) {
  .setting form {
    padding: 16px;
  }
}
.setting form .form__title {
  font-weight: 500;
  margin-bottom: 8px;
}
.setting form .form__input {
  margin-bottom: 32px;
}
.setting form .form__input .input {
  width: 100%;
}
.setting form .form__flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 40px;
}
@media screen and (max-width: 768px) {
  .setting form .form__flex {
    gap: 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.setting form .form__flex div {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
.setting form .form__notice {
  font-weight: 500;
  color: #EF0000;
  margin-bottom: 8px;
}
.setting form .required {
  color: #EF0000;
}
.setting form .button {
  font-weight: 500;
  margin: auto;
}

/*【レポート】*/
body.report .form {
  padding: 0px 80px 80px 80px;
  background: #fff;
  border-radius: 24px;
  max-width: 800px;
  margin: 24px auto;
}
@media screen and (max-width: 768px) {
  body.report .form {
    padding: calc(100vw / 375 * 0 / 1.618) calc(100vw / 375 * 80 / 1.618) calc(100vw / 375 * 80 / 1.618) calc(100vw / 375 * 80 / 1.618);
  }
}
@media screen and (max-width: 768px) {
  body.report .form {
    border-radius: 0;
    padding: 0px 16px 16px 16px;
    margin: 24px -16px;
  }
}
body.report .form h3 {
  border-radius: 24px 24px 0px 0px;
  padding: 40px 80px;
  margin: 0px -80px 24px -80px;
  background: #bee8ff;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  body.report .form h3 {
    padding: calc(100vw / 375 * 40 / 1.618) calc(100vw / 375 * 80 / 1.618);
  }
}
@media screen and (max-width: 768px) {
  body.report .form h3 {
    margin: calc(100vw / 375 * 0 / 1.618) calc(100vw / 375 * -80 / 1.618) calc(100vw / 375 * 24 / 1.618) calc(100vw / 375 * -80 / 1.618);
  }
}
@media screen and (max-width: 768px) {
  body.report .form h3 {
    margin: 9px -16px 24px -16px;
    border-radius: 0px;
    padding: 14px 16px;
  }
}
body.report .form h3 img {
  display: inline-block;
  height: 20px;
  margin-right: 8px;
}
body.report .form h4 {
  padding-bottom: 8px;
  border-bottom: 1px solid #95A5A5;
  margin-bottom: 24px;
}
body.report .form .form__excuse {
  font-size: 14px;
  margin: 0px 0px 32px 0px;
}
@media screen and (max-width: 768px) {
  body.report .form .form__excuse {
    margin: calc(100vw / 375 * 0 / 1.618) calc(100vw / 375 * 0 / 1.618) calc(100vw / 375 * 32 / 1.618) calc(100vw / 375 * 0 / 1.618);
  }
}
body.report .form .form__title {
  font-weight: bold;
  margin-bottom: 8px;
}
body.report .form .form__input {
  margin: 0px 0px 24px 0px;
}
@media screen and (max-width: 768px) {
  body.report .form .form__input {
    margin: calc(100vw / 375 * 0 / 1.618) calc(100vw / 375 * 0 / 1.618) calc(100vw / 375 * 24 / 1.618) calc(100vw / 375 * 0 / 1.618);
  }
}
body.report .form .form__input .input {
  width: 100%;
}
body.report .form .form__media {
  position: relative;
  padding: 16px;
  /*aspect-ratio: 1.618/1;*/
  padding-top: calc(500 / 800 * 100%); 

  width: 100%;
  background: #F8F8F8;
  border: 1px solid #EBECEC;
  margin: 0px 0px 32px 0px;

}
@media screen and (max-width: 768px) {
  body.report .form .form__media {
    margin: calc(100vw / 375 * 0 / 1.618) calc(100vw / 375 * 0 / 1.618) calc(100vw / 375 * 32 / 1.618) calc(100vw / 375 * 0 / 1.618);
  }
}

body.report .form .form__media.vertical {
  position: relative;
  padding: 16px;
  /*aspect-ratio: 1.618/1;*/
  padding-top: calc(800 / 500 * 100%); 
  width: auto;
  height: 80%;
  background: #F8F8F8;
  border: 1px solid #EBECEC;
  margin: 0px 0px 32px 0px;
}

body.report .form .form__media .form__uploaded {
  position: absolute;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  left: 0;
  top: 0;
  -o-object-position: center center;
     object-position: center center;
  z-index: 10;
  background: #F8F8F8;
}
body.report .form .form__media .media__upload {
  text-align: center;
  /*aspect-ratio: 1.2/1;*/
  padding-top: calc(280 / 600 * 100%); 

  width: 320px;
  max-width: calc(100% / 342 * 218);
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  background: #fff;
  border: 1px dashed #707070;
  font-weight: 500;
}
body.report .form .form__media .media__upload p {
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  font-size: 14px;
  padding: 16px;
  width: 100%;
}
@media screen and (max-width: 768px) {
  body.report .form .form__media .media__upload p {
    font-size: calc(100vw / 375 * 14 / 1.618 );
  }
}
@media screen and (max-width: 606.75px) {
  body.report .form .form__media .media__upload p {
    font-size: 14px;
  }
}
body.report .form .form__media .media__upload p img {
  width: 34.5px;
  display: block;
  margin: auto auto 12px auto;
}
body.report .form .form__flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-line-pack: start;
      align-content: flex-start;
  gap: 16px;
}
@media screen and (max-width: 768px) {
  body.report .form .form__flex {
    gap: 8px;
  }
}
body.report .form .form__flex .flex__child {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
body.report .form .form__flex .flex__child--double {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 200%;
          flex: 1 1 200%;
}
body.report .form .form__flex .flex__child--single {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 100%;
          flex: 1 1 100%;
}
body.report .form .form__grid {
  display: -ms-grid;
  display: grid;
  -ms-grid-rows: 193px;
  grid-template-rows: 193px;
  -ms-grid-columns: 50% 16px 1fr;
  grid-template-columns: 50% 1fr;
  gap: 32px 16px;
}
body.report .form .form__grid > *:nth-child(1) {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
}
body.report .form .form__grid > *:nth-child(2) {
  -ms-grid-row: 1;
  -ms-grid-column: 3;
}
body.report .form .form__grid .grid__child--data {
  -ms-grid-row: 1;
  -ms-grid-row-span: 2;
  grid-row: 1/3;
  -ms-grid-column: 2;
  -ms-grid-column-span: 1;
  grid-column: 2/3;
}
@media screen and (max-width: 768px) {
  body.report .form .form__grid {
    display: block;
  }
}
body.report .form input[type=radio] {
  display: none;
}
body.report .form input[type=radio] + label {
  border: 1px solid #EBECEC;
  text-align: center;
  color: #95A5A5;
  font-size: 18px;
  background-color: #F8F8F8;
  padding: 13px;
  border-radius: 4px;
  width: 100%;
  display: block;
}
body.report .form input[type=radio]:checked + label {
  color: #fff;
  border: none;
  background: #04a1f4;
}

/*【フッター】*/
footer {
  color: #717777;
  font-size: 14px;
  padding-bottom: 40px;
  padding-left: 16px;
  padding-right: 16px;
}
footer .footer__flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  max-width: 800px;
  margin: auto;
}
@media screen and (max-width: 768px) {
  footer .footer__flex {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    text-align: center;
  }
}
footer .footer__flex .footer__child--links {
  text-align: right;
}
@media screen and (max-width: 768px) {
  footer .footer__flex .footer__child--links {
    text-align: center;
    margin-top: 24px;
  }
}
/*# sourceMappingURL=style.css.map */