@charset "UTF-8";
*, ::before, ::after {
  box-sizing: border-box;
  border-style: solid;
  border-width: 0;
}

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

body {
  margin: 0;
}

main {
  display: block;
}

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

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

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

dt {
  font-weight: 700;
}

dd {
  margin-left: 0;
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
  border-top-width: 1px;
  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] {
  -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;
}

svg, img, embed, object, iframe {
  vertical-align: bottom;
}

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

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

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

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

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

:-moz-focusring {
  outline: auto;
}

select:disabled {
  opacity: inherit;
}

option {
  padding: 0;
}

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

legend {
  padding: 0;
}

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]:focus {
  outline: auto;
}

table {
  border-color: inherit;
}

caption {
  text-align: left;
}

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

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

html {
  font-size: 62.5%;
}

body {
  font-size: 1.6rem;
  font-size: clamp(14px, 1.82vw, 16px);
  line-height: 1.8;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
  color: #343A40;
  background: #F4F4F4;
}

a {
  text-decoration: none;
  transition: 0.2s ease-in-out;
  color: #3097D1;
}

a[href^="tel:"] {
  pointer-events: none;
  cursor: default;
}

p {
  font-size: 1.6rem;
}
@media screen and (max-width: 520px) {
  p {
    font-size: 1.4rem;
  }
}

label {
  font-size: 1.2rem;
}

.label_gekkan {
  background-color: #11b4d9;
  color: #fff;
  font-size: 1.5rem;
  font-weight: bold;
  padding: 0.4rem 2rem;
  margin-bottom: 1.6rem;
  border-radius: 5px;
}

@media screen and (max-width: 620px) {
  .label_gekkan {
    font-size: 1.5rem;
    padding: 0.2rem;
    width: 65%;
    text-align: center;
  }
}
svg {
  width: 100%;
  height: 100%;
}

h1 {
  font-size: 2.8rem;
  font-size: clamp(22px, 2.864vw, 28px);
  font-weight: normal;
  display: flex;
  align-items: center;
}
h1 .icon-back {
  width: 22px;
  height: 22px;
  display: block;
  margin-right: 1.6rem;
  display: flex;
  align-items: center;
}

h2 {
  font-size: 2.4rem;
  font-size: clamp(20px, 2.6vw, 24px);
  font-weight: normal;
}

h3 {
  font-size: 2rem;
  font-size: clamp(18px, 2.34vw, 20px);
  font-weight: normal;
}

h4 {
  font-size: 1.8rem;
  font-size: clamp(16px, 2.08vw, 18px);
  font-weight: normal;
}

.bold {
  font-weight: bold;
}

@media (hover: hover) {
  a {
    transition: all ease 0.2s;
    will-change: opacity;
  }

  input,
button,
textarea,
select {
    font-size: 1.6rem;
  }
  input:focus,
button:focus,
textarea:focus,
select:focus {
    outline: none;
  }
}
a:link,
a:visited {
  text-decoration: none;
}

a:hover,
a:visited {
  text-decoration: none;
}

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

input,
textarea {
  border-radius: 3px;
  border: 1px solid #DBDBDB;
  padding: 0.3rem 1rem;
}

::-moz-placeholder {
  color: #dbdbdb;
}

:-ms-input-placeholder {
  color: #dbdbdb;
}

::placeholder {
  color: #dbdbdb;
}

.wrap {
  width: min(96%, 1200px);
  margin: auto;
}

.wrap-inner {
  padding: 0 2.5%;
}
@media screen and (max-width: 768px) {
  .wrap-inner .wrap_inner {
    padding: 0 2%;
    overflow: hidden;
  }
}

.sp {
  display: none;
}
@media screen and (max-width: 768px) {
  .sp {
    display: block !important;
  }
}

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

.flex-row {
  display: flex;
  justify-content: space-between;
}

.box {
  padding: clamp(1.6rem, 3vmax, 2rem) clamp(1.6rem, 3vmax, 4rem);
  margin: clamp(2rem, 2vh, 4rem) 0;
  background: #fff;
}

.btn {
  display: inline-block;
  padding: 1.2rem 2rem;
  line-height: 1;
  border-radius: 5px;
  font-size: 1.6rem;
  font-weight: bold;
}
.btn.primary {
  border-radius: 50px;
  color: #11B4D9;
  border: 1px solid #11B4D9;
}
.btn.primary:hover {
  color: #fff;
  background: #11B4D9;
}
@media screen and (max-width: 520px) {
  .btn.primary {
    padding: 1.2rem 1.5rem;
    width: auto !important;
  }
}
.btn.secondary {
  color: #939CA0;
  border: 1px solid #939CA0;
}
.btn.secondary:hover {
  color: #fff;
  background: #939CA0;
}
.btn.success {
  color: #28A745;
  border: 1px solid #28A745;
}
.btn.success:hover {
  color: #fff;
  background: #28A745;
}
.btn.danger {
  color: #ED4C5B;
  border: 1px solid #ED4C5B;
}
.btn.danger:hover {
  color: #fff;
  background: #ED4C5B;
}
.btn.warning {
  color: #FFC107;
  border: 1px solid #FFC107;
}
.btn.warning:hover {
  color: #fff;
  background: #FFC107;
}
.btn.info {
  color: #17A2B8;
  border: 1px solid #17A2B8;
}
.btn.info:hover {
  color: #fff;
  background: #17A2B8;
}
.btn.light {
  color: #343A40;
  border: 1px solid #F8F9FA;
}
.btn.light:hover {
  background: #F8F9FA;
}
.btn.dark {
  color: #343A40;
  border: 1px solid #343A40;
}
.btn.dark:hover {
  color: #fff;
  background: #343A40;
}

.icon--bell {
  width: 30px;
  height: 30px;
  position: relative;
  display: block;
}
.icon--bell span {
  position: absolute;
  top: -1px;
  right: -1px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #ED4C5B;
}

.login.contentWrap {
  display: flex;
}

.logout.contentWrap {
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
}

.main {
  padding: clamp(1.6rem, 3vmax, 4rem) 2.5rem;
  flex: 1;
}

@media screen and (max-width: 520px) {
  .main {
    padding: 8px;
  }
  .main:not(:has(.sticky-area)) h1 {
    display: block;
    text-align: center;
  }
}
.logout .main {
  width: 100%;
}

.modal {
  display: none;
  position: fixed;
  z-index: 20;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  background: rgba(0, 0, 0, 0.5);
}
.modal.is_open {
  display: block;
  -webkit-animation: modalopen 0.4s;
          animation: modalopen 0.4s;
}
.modal .modal-content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: #f4f4f4;
  padding: 60px 6vw 40px;
  width: min(95%, 800px);
  border-radius: 10px;
}
@media screen and (max-width: 520px) {
  .modal .modal-content {
    top: 20px;
    transform: translateX(-50%);
    overscroll-behavior-y: contain;
  }
}
.modal .closeBtn {
  color: #11B4D9;
  font-size: 4rem;
  line-height: 1;
  cursor: pointer;
  margin-bottom: 24px;
  position: absolute;
  left: 20px;
  top: 20px;
}
.modal .form-alert {
  text-align: center;
  padding: 0 40px 80px;
}
.modal .form-alert h1 {
  margin-bottom: 20px;
}
.modal .form-alert p {
  margin-bottom: 20px;
}
.modal .form-alert input[type=text],
.modal .form-alert input[type=password] {
  width: 100%;
  text-align: left;
}
.modal .form-alert .signinContainer {
  margin-top: 40px;
}
.modal .form-alert .signinContainer .login-btn {
  border-radius: 50px;
  color: #fff;
  background: #11B4D9;
  border: 1px solid #11B4D9;
  width: 100%;
  text-align: center;
}
.modal .form-alert .signinContainer .login-btn:hover {
  color: #11B4D9;
  background: #fff;
}

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

@keyframes modalopen {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
select {
  font-size: 1.6rem;
  background: #fff;
  width: 100%;
}
select:focus {
  outline: none;
}

.custom-select {
  position: relative;
  display: inline-block;
}
.custom-select .custom-arrow {
  position: absolute;
  right: 0;
  top: 0;
  display: block;
  height: 100%;
  width: 1em;
  pointer-events: none;
}
.custom-select .custom-arrow::after {
  content: "";
  position: absolute;
  width: 10px;
  height: 10px;
  margin-top: -3px;
  border-left: 2px solid #343A40;
  border-bottom: 2px solid #343A40;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) rotate(314deg);
}

table.default {
  border: 1px solid #11B4D9;
  margin-bottom: 20px;
  border-collapse: collapse;
  width: 100%;
}
table.default th {
  text-align: center;
  vertical-align: middle;
  background: #E8F2F6;
  color: #11B4D9;
  padding: 12px;
  font-weight: bold;
  border: 1px solid #11B4D9;
  width: 105px;
}
table.default th.left {
  text-align: left;
}
table.default td {
  padding: 12px;
  border: 1px solid #11B4D9;
  text-align: left;
}
table.default td.center {
  text-align: center !important;
}
table.default td.right {
  text-align: right !important;
}
table.default td.v-middle {
  vertical-align: middle;
}
@media screen and (max-width: 768px) {
  table.default th,
table.default td {
    padding: 8px;
  }
}
@media screen and (max-width: 520px) {
  table.default th,
table.default td {
    width: auto;
  }
  table.default th.left > div > div {
    width: 100% !important;
  }
}

.selevalpointcheck {
  padding: 0 !important;
}

.flex-title {
  display: flex;
  justify-content: space-between;
  justify-content: flex-start;
  align-items: center;
}
.flex-title .--subTitle {
  color: #11B4D9;
  font-size: 1.6rem;
  margin-left: 1.6rem;
}

.flex-col {
  display: flex;
  justify-content: space-between;
  position: relative;
}
.flex-col.col-3 {
  gap: 16px;
}
.flex-col.col-3 > * {
  flex: 1;
}

@media screen and (max-width: 520px) {
  .flex-col.col-3 {
    gap: 8px;
  }
  .flex-col.col-3 table.default {
    width: 33%;
  }
  .flex-col.col-3 table.default tr {
    display: flex;
    flex-direction: column;
  }
  .flex-col.col-3 table.default th {
    width: 100%;
  }
  .flex-col.col-3 table.default td {
    min-height: 41.6px;
    padding: 8px 0;
  }
}
header.header {
  width: 100%;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: 10;
  height: 90px;
  padding: max(1.7vh, .3rem) 1.5rem max(2vh, .5rem) 1.5rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #fff;
  border-bottom: 1px solid #DBDBDB;
}
header.header h1.logo a {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  font-size: 1.8rem;
  font-weight: bold;
  color: #000;
  gap: 20px;
}
header.header h1.logo a > img {
  width: 230px;
}
@media screen and (max-width: 768px) {
  header.header h1.logo {
    width: 255px;
  }
}
header.header .header-nav {
  margin-left: auto;
  display: flex;
  justify-content: space-between;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
}
header.header .header-nav .staff {
  padding: 6px 12px;
  display: inline-block;
  line-height: 1;
  font-size: 1.2rem;
  font-weight: bold;
  background: #E8F2F6;
  color: #11B4D9;
  border-radius: 5px;
}
header.header .header-nav .leader {
  padding: 6px 12px;
  display: inline-block;
  line-height: 1;
  font-size: 1.2rem;
  font-weight: bold;
  background: #11B4D9;
  color: #fff;
  border-radius: 5px;
}
header.header .header-nav .avator {
  width: 34px;
}
@media screen and (max-width: 768px) {
  header.header {
    height: 80px;
  }
  header.header .header-nav {
    display: none;
  }
}

@media screen and (max-width: 520px) {
  header.header {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  #spnavArea {
    display: block;
  }
}
#spnavArea nav {
  display: block;
  position: fixed;
  background-color: #fff;
  top: 0;
  left: -100%;
  bottom: 0;
  padding-top: 70px;
  width: 80%;
  transition: all 0.35s cubic-bezier(0.69, 0.27, 0.04, 0.97);
  z-index: 30;
  opacity: 0;
}
#spnavArea nav .inner {
  padding: 25px;
}
#spnavArea nav .inner li {
  border-bottom: 1px solid #333;
}
#spnavArea nav .inner li a {
  display: block;
  color: #333;
  font-size: 1.6rem;
  padding: 1rem;
  transition-duration: 0.2s;
}
#spnavArea nav .inner .spnav-footer a {
  color: #333;
}
#spnavArea .toggle-btn {
  display: block;
  position: fixed;
  top: 30px;
  right: 30px;
  width: 65px;
  height: 65px;
  z-index: 3;
  cursor: pointer;
  border-radius: 50%;
}
@media screen and (max-width: 768px) {
  #spnavArea .toggle-btn {
    top: 10px;
    right: 10px;
  }
}
#spnavArea .toggle-btn span {
  position: absolute;
  display: block;
  left: 0;
  right: 0;
  width: 30px;
  margin: 0 auto;
  height: 2px;
  background-color: #fff;
  transition: all 0.5s;
  border-radius: 4px;
}
#spnavArea .toggle-btn span:nth-child(1) {
  top: 14px;
}
#spnavArea .toggle-btn span:nth-child(2) {
  top: 22px;
}
#spnavArea .toggle-btn span:nth-child(3) {
  top: 30px;
}
#spnavArea .toggle-btn span.txt {
  height: auto;
  background-color: transparent;
  color: #fff;
  font-size: 12px;
  top: 37px;
}
#spnavArea #mask {
  display: none;
  transition: all 0.5s;
}
#spnavArea.open nav {
  left: 0;
  opacity: 1;
}
#spnavArea.open #mask {
  display: block;
  background-color: rgba(0, 0, 0, 0.8);
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  position: fixed;
  cursor: pointer;
}
#spnavArea.open .toggle-btn span {
  background-color: #fff;
}
#spnavArea.open .toggle-btn span:nth-child(1) {
  transform: translateY(9px) rotate(-315deg);
}
#spnavArea.open .toggle-btn span:nth-child(2) {
  opacity: 0;
}
#spnavArea.open .toggle-btn span:nth-child(3) {
  transform: translateY(-7px) rotate(315deg);
}
#spnavArea.open .toggle-btn span:nth-child(4) {
  background-color: transparent;
}

.side {
  flex-shrink: 0;
  overflow: hidden;
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: flex-start;
  justify-content: stretch;
  width: 75px;
  height: calc(100vh - 90px);
  background: #fff;
  padding: clamp(1.6rem, 3vmax, 4rem) 0 0 0;
  position: -webkit-sticky;
  position: sticky;
  left: 0;
  top: 90px;
}
.side--menu {
  padding-bottom: 2rem;
  margin-bottom: 2rem;
  border-bottom: 1px solid #ccc;
  width: 100%;
  overflow-y: auto;
  overflow-x: hidden;
}
@media screen and (max-width: 520px) {
  .side--menu {
    overflow: hidden;
    display: inline-table;
    padding-top: 20px;
  }
}
.side--footer {
  width: 100%;
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: flex-start;
}
@media screen and (max-width: 520px) {
  .side--footer2 {
    padding-bottom: 60px;
  }
}
.side .side-link {
  font-weight: bold;
  color: #343A40;
  display: flex;
  width: 100%;
  padding: 1.5rem 0;
  align-items: center;
  padding-left: 2.5rem;
  cursor: pointer;
  position: relative;
}
.side .side-link:hover {
  background: #E8F2F6;
}
.side .side-link .side-icon {
  display: inline-block;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  fill: #12b4d9;
}
.side .side-link .alert {
  color: #fff;
  background-color: #ED4C5B;
  width: 20px;
  height: 20px;
  text-align: center;
  display: inline-block;
  border-radius: 100%;
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.2rem;
}
.side .side-link .side-icon24 {
  display: inline-block;
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  fill: #12b4d9;
}
.side .hidden-sidebar {
  opacity: 0;
  width: 0;
  transition: opacity 200ms ease-in-out;
  margin-left: 1.2rem;
  white-space: nowrap;
}
.side .sub-side-list-item {
  height: 0;
  max-height: 0;
  overflow: hidden;
}
.side .sub-side-list-item .side-link {
  padding-left: 5rem;
  font-size: 1.2rem;
}
.side .sub-side-list.active .sub-side-list-item {
  z-index: 1;
  height: auto;
  max-height: 50em;
  transition: 2s linear;
}

.side.open {
  width: 240px;
}
.side.open .hidden-sidebar {
  width: 100%;
  height: auto;
  opacity: 1;
}
.side.open .side-link {
  justify-content: flex-start;
}

@media screen and (max-width: 520px) {
  .side {
    top: 60px;
    height: calc(100vh - 60px);
  }
  .side .side-link {
    padding: 1rem 0 1rem 2.5rem;
  }
  .side.user-sidemenu {
    overflow: hidden;
    display: inline-table;
    position: fixed;
    left: -100%;
    z-index: 50;
    width: 100%;
  }
  .side.user-sidemenu.open {
    display: flex;
    top: 0;
    left: 0;
    height: 100vh;
    overflow-y: scroll;
    padding-top: 0;
    overscroll-behavior-y: contain;
  }
}
.footer {
  padding: 20px 0;
  position: relative;
}
.footer h2 {
  text-align: center;
  font-size: 4rem;
}
.footer h2 > span {
  display: block;
  font-size: 2rem;
  margin-bottom: 20px;
}
.footer p.copy {
  text-align: center;
  font-size: 1.2rem;
  color: #a2a2a2;
}

@-webkit-keyframes fadeIn {
  0% {
    display: none;
    opacity: 0;
  }
  1% {
    display: block;
    opacity: 0;
  }
  100% {
    display: block;
    opacity: 1;
  }
}

@keyframes fadeIn {
  0% {
    display: none;
    opacity: 0;
  }
  1% {
    display: block;
    opacity: 0;
  }
  100% {
    display: block;
    opacity: 1;
  }
}
@-webkit-keyframes fadeEffect {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes fadeEffect {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.login-form {
  width: min(96%, 624px);
  margin: 0 auto;
  background: #fff;
  padding: clamp(4rem, 10vmax, 10rem) 11rem;
}
@media screen and (max-width: 768px) {
  .login-form {
    padding: clamp(3rem, 6vmax, 10rem) 3rem;
  }
}
.login-form h1 {
  margin-bottom: 10px;
  text-align: center;
}
.login-form h2 {
  text-align: center;
  margin-bottom: 40px;
}
.login-form dl {
  margin-bottom: 20px;
}
.login-form input[type=text],
.login-form input[type=password] {
  width: 100%;
}
.login-form .signinContainer {
  margin-top: 20px;
}
.login-form .signinContainer .login-btn {
  border-radius: 50px;
  color: #fff;
  background: #11B4D9;
  border: 1px solid #11B4D9;
  width: 100%;
  text-align: center;
}
.login-form .signinContainer .login-btn:hover {
  color: #11B4D9;
  background: #fff;
}
.login-form .forgotPass {
  margin-top: 40px;
  text-align: center;
}
.login-form .modalBtn {
  color: #11B4D9;
}

.sort-area {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

@media screen and (max-width: 620px) {
  .sort-area {
    display: flex;
    flex-direction: column;
  }
}
@media screen and (max-width: 520px) {
  .sort-area {
    padding: 0 !important;
  }
}
.c {
  align-items: right;
}

.wrap_content__set2 {
  align-items: left;
}

@media screen and (max-width: 620px) {
  .wrap_content__set1 {
    margin-bottom: 0.5rem;
    display: flex;
    flex-direction: column;
    align-items: left !important;
  }

  .wrap_content__set2 {
    margin-bottom: 2rem;
  }
}
@media screen and (max-width: 520px) {
  .wrap_content__set1 {
    flex-direction: row !important;
    flex-wrap: wrap;
  }
  .wrap_content__set1 .custom-select {
    width: 50%;
    padding: 8px;
    margin-right: 0 !important;
    margin-left: 0 !important;
    margin-bottom: 1rem;
  }
  .wrap_content__set1 .custom-search {
    width: 100%;
  }
  .wrap_content__set1 .custom-search input[type=text] {
    width: 100%;
    padding: 0.4rem;
  }
  .wrap_content__set1 .custom-search button {
    border: 1px solid #11b4d9;
  }

  .wrap_content__set2 {
    margin: 1rem 0 !important;
  }
}
.lock-unlock {
  font-size: 1.2rem;
  margin-top: 1.6rem;
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  fill: #11B4D9;
}
.lock-unlock .icon {
  margin-right: 10px;
  width: 24px;
  height: 24px;
  fill: #11B4D9;
}
@media screen and (max-width: 520px) {
  .lock-unlock {
    margin-top: 1rem;
  }
}

.post-area .post-item {
  border-bottom: 1px solid #dbdbdb;
  margin: 1rem;
}
.post-area .post-item a {
  display: flex;
  align-items: center;
  color: #343A40;
  padding: clamp(1.6rem, 3vmax, 2rem) clamp(1.2rem, 3vmax, 2rem);
}
.post-area .post-item a.unread {
  background-color: #fcf8e5;
}
.post-area .post-item a .icon-image {
  position: relative;
  width: 34px;
  height: 34px;
  margin-right: 1.6rem;
  flex-shrink: 0;
}
.post-area .post-item a .icon-image .icon {
  width: 34px;
  height: 34px;
  fill: #DBDBDB;
}
.post-area .post-item a .icon-image .lock {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-66%, -50%);
  width: 20px;
  height: 20px;
  fill: #11B4D9;
}
.post-area .post-item a .post-title {
  flex: 1;
}
.post-area .post-item a .post-date {
  margin-left: auto;
  width: 120px;
  font-size: 1.2rem;
}
.post-area .post-item a.unread {
  background-color: #fcf8e5;
}
@media screen and (max-width: 520px) {
  .post-area .post-item a {
    padding: 0;
  }
}
.post-area i.fa.fa-exclamation {
  color: #ffcd00;
  padding-right: 0.5em;
}

.post-area .post-item a .icon-image1 {
  position: relative;
  width: 34px;
  height: 34px;
  margin-right: 1.6rem;
  flex-shrink: 0;
}

.icon-image2 {
  position: relative;
  width: 34px;
  height: 34px;
  margin-right: 1.6rem;
  flex-shrink: 0;
  display: block;
  border-radius: 50%;
  overflow: hidden;
  background-color: #dee2e6;
}

.post-area .post-item a .icon-image1 .icon {
  width: 34px;
  height: 34px;
  fill: #dbdbdb;
}

.icon-image2 .icon {
  width: 34px;
  height: 34px;
  fill: #dbdbdb;
}

.post-area .post-item a .icon-image1 .lock {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-66%, -50%);
  width: 20px;
  height: 20px;
  fill: #11b4d9;
}

@media screen and (max-width: 520px) {
  .post-area .post-item .post-date {
    text-align: right;
  }
  .post-area .post-item .wrap__thumbnai {
    width: 100%;
  }
  .post-area .post-item a .post-title {
    align-items: start;
  }
  .post-area .post-item a .icon-image1 {
    width: 28px;
    margin-right: 1rem;
  }
  .post-area .post-item a .icon-image1 .icon {
    width: 28px;
  }
}
.alart-area {
  border: 2px solid #ffcd00;
}
.alart-area i.fa.fa-exclamation-triangle {
  color: #ffcd00;
  padding-right: 0.5em;
}

.btn_default {
  display: block;
}

.sort-area_responsive {
  display: none;
}

@media screen and (max-width: 620px) {
  .wrap {
    display: flex;
    flex-flow: column;
  }

  .btn_default {
    display: none;
  }

  .sort-area_responsive {
    display: block;
    margin: 1rem 0;
  }
}
.sticky-area {
  position: -webkit-sticky;
  position: sticky;
  top: 90px;
  z-index: 20;
  background: #F4F4F4;
}
.sticky-area .sticky-head {
  margin-bottom: 20px;
}

@media screen and (max-width: 520px) {
  .sticky-area {
    position: static;
  }
  .sticky-area h1 {
    font-size: 1.8rem;
    line-height: 1.3;
  }
}
.wrapper-content {
  background-color: white;
  padding: 2.5%;
  position: relative;
}

@media screen and (max-width: 768px) {
  .wrapper-content .group:nth-of-type(2) .evalGrid div:nth-of-type(n+2) table {
    height: 80px;
  }
  .wrapper-content .group:nth-of-type(3) .evalGrid div:nth-of-type(n+2) table {
    height: 115px;
  }
}
.tab-head {
  background: #fff;
}
@media screen and (max-width: 520px) {
  .tab-head {
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    z-index: 20;
    display: block;
    transition: 0.5s;
  }
  .tab-head.hide {
    top: -100px;
    transition: 0.5s;
  }
}

/* Tabs menu */
.tabNav {
  margin: 0;
  display: flex;
  justify-content: space-between;
  border-radius: 2px 2px 0px 0px;
  border-bottom: 1px solid #DBDBDB;
}

.tab-title {
  position: -webkit-sticky;
  position: sticky;
  top: 152px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #fff;
  padding: 30px;
}
.tab-title h2 {
  font-weight: bold;
}

@media screen and (max-width: 520px) {
  .tab-title {
    flex-direction: column;
    padding: 8px;
  }
  .tab-title h2 {
    display: none;
    margin-bottom: 8px;
    font-size: 18px;
  }
  .tab-title .tools {
    width: 100%;
    text-align: center;
  }
  .tab-title .tools button:nth-of-type(3) {
    width: auto !important;
  }
}
.clear-radios {
  display: none;
}

.editMode .tab-title button:not(.now) {
  opacity: 0.3;
  pointer-events: none;
}
.editMode .tabNav button {
  opacity: 0.3;
  pointer-events: none;
}
.editMode .clear-radios {
  display: block;
  position: absolute;
  top: -54px;
  right: 0;
  text-align: center;
  background: #E8F2F6;
  color: #11B4D9;
  padding: 5px 12px;
  font-weight: bold;
  border: 1px solid #11B4D9;
  width: 105px;
  border-radius: 8px;
}

@media screen and (max-width: 520px) {
  .editMode .tab-title button:not(.now) {
    display: none;
  }
}
/* Tab Links */
.tablinks {
  border: none;
  outline: none;
  cursor: pointer;
  position: relative;
  font-size: clamp(14px, 2.08vw, 18px);
  transition: 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  transition: 0.5s ease;
  padding: 20px;
  margin: 0;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  font-weight: 400;
  flex: 1;
}
@media screen and (max-width: 768px) {
  .tablinks {
    padding: 14px 10px;
  }
}
@media screen and (max-width: 520px) {
  .tablinks {
    padding: 8px;
  }
}

.tablinks:before {
  content: "";
  width: 100%;
  height: 0px;
  position: absolute;
  bottom: 0;
  left: 0;
  transition: 0.3s ease-in-out;
  z-index: 2;
}

/* Tab active */
.tablinks.active:before {
  content: "";
  width: 100%;
  height: 3px;
  bottom: 0;
  left: 0;
  background: #11B4D9;
}

/* Tabs text */
.tablinks.active,
.tablinks.active:hover {
  color: #11B4D9;
  font-weight: bold;
}

.tablinks:hover {
  color: #11B4D9;
  opacity: 1;
}

/* tab content */
.wrapper-tabcontent {
  background-color: white;
  padding: 2.5%;
  position: relative;
}

.tabcontent {
  display: none;
  margin: 0;
  padding: 0;
  line-height: 28px;
  font-weight: 100;
  transition: all 1s ease;
  -webkit-animation: fadeEffect 0.6s ease;
          animation: fadeEffect 0.6s ease;
  width: 100%;
  font-size: 16px;
}
@media screen and (max-width: 512px) {
  .tabcontent {
    font-size: 14px;
    line-height: 26px;
  }
}

.tabcontent.active {
  transition: all 1s ease;
  display: block;
}

.intro {
  background-color: #E8F2F6;
  padding: 2rem;
  border-radius: 8px;
  margin-bottom: 40px;
}
.intro .btn {
  background: #fff;
  margin: 20px auto 0;
  width: 300px;
  text-align: center;
  display: block;
}
.intro .btn:hover {
  background: #11B4D9;
}

@media screen and (max-width: 520px) {
  .intro {
    padding: 1.4rem;
    margin-bottom: 20px;
  }
  .intro .btn {
    width: auto;
  }
}
.group {
  margin-bottom: 46px;
}
.group h3.step-title {
  font-size: 24px;
  font-weight: bold;
  color: #11B4D9;
  margin-bottom: 20px;
}
.group .label {
  background: #11B4D9;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 128px;
  height: 40px;
  font-size: 1.6rem;
  border-radius: 5px;
  margin-bottom: 1.6rem;
}
.group .label > em {
  font-size: 2.8rem;
  font-style: normal;
  margin-left: 6px;
}
.group p {
  line-height: 1.7;
  margin-bottom: 1.6rem;
}
.group input[type=text] {
  border: 1px solid #11B4D9;
  padding: 0.5rem 1rem;
  width: 100%;
  box-sizing: border-box;
}
.group .clear-radios {
  margin-left: auto;
}

@media screen and (max-width: 520px) {
  .group {
    margin-bottom: 32px;
  }
  .group .label {
    width: 100px;
    height: 30px;
  }
  .group h3.step-title {
    font-size: 2.2rem;
  }

  #seet-daily table.default:not(.feedback-area) tr {
    display: flex;
    flex-direction: column;
  }
}
.feature {
  border: 1px solid #11B4D9;
  margin-bottom: 20px;
}
.feature h4 {
  padding: 10px;
  text-align: center;
  color: #fff;
  background: #11B4D9;
  font-size: 2rem;
  font-weight: bod;
}
.feature p {
  padding: 16px 20px;
}
.feature p:first-child {
  position: relative;
}
.feature p:first-child span.date {
  position: absolute;
  bottom: -1.5em;
  right: 0.5em;
  font-size: 11px;
  color: #666;
}
.feature table.default {
  margin-bottom: 0;
}

.hint {
  position: absolute;
  right: 0;
  opacity: 0;
}
.hint .btn {
  display: flex;
  gap: 10px;
}
.hint .btn:hover .icon {
  fill: #fff;
}
.hint .icon {
  fill: #11B4D9;
  width: 20px;
  height: 20px;
}

.editMode .hint {
  opacity: 1;
  transition: opacity 0.2s;
}

.hint-title {
  background-color: #E8F2F6;
  display: flex;
  justify-content: space-between;
  justify-content: center;
  border-radius: 20px;
  padding: 6px;
}
.hint-title .icon {
  fill: #11B4D9;
  width: 20px;
  height: 20px;
  margin-right: 10px;
}
.hint-title > span {
  color: #11B4D9;
}

.hint-cat {
  text-align: center;
  margin: 20px 0;
}

.hint-lead {
  margin-bottom: 20px;
}

.hint-content {
  margin-bottom: 20px;
}
.hint-content dt {
  color: #11B4D9;
  margin-bottom: 10px;
}
.hint-content dd {
  border: 1px solid #11B4D9;
  padding: 5px 10px;
}

.day-title {
  display: flex;
  justify-content: space-between;
  justify-content: flex-start;
  align-items: center;
  margin-bottom: 1.6rem;
  line-height: 1;
}
.day-title > span {
  font-size: 2.8rem;
  color: #11B4D9;
}
.day-title .d-week {
  font-size: 1.6rem;
  margin-left: 2rem;
  color: #343A40;
}
.day-title .icon-wrap {
  position: relative;
  display: flex;
  align-items: center;
  gap: 1.4rem;
}
.day-title .icon-checked-wrap {
  display: table;
  padding-left: 4.4rem;
}
.day-title .icon-checked-wrap label {
  display: table-cell;
  vertical-align: middle;
}
.day-title .icon-checked-wrap .daily-checkBox {
  display: none;
}
.day-title .icon-checked-wrap .icon-checked {
  display: none;
}
.day-title .icon-checked-wrap .icon-checked.active {
  display: inline-block;
}
.day-title .icon-checked-wrap input:checked + .icon-checked {
  display: inline-block;
  margin-right: 1rem;
}
.day-title .icon-group {
  display: none;
  opacity: 0;
  visibility: hidden;
  transition: all 0.4s;
  position: absolute;
  top: -80px;
  left: -8rem;
  padding: 0.8rem 1.4rem;
  background: #f4f4f4;
  border-radius: 10px;
  z-index: 5;
  display: flex;
  gap: 12px;
}
.day-title .icon-group.is-open {
  opacity: 1;
  visibility: visible;
  transition: all 0.4s;
}
.day-title .icon-group:before {
  content: "";
  width: 0;
  height: 0;
  border-left: 8px solid transparent;
  border-top: 17px solid #f4f4f4;
  border-right: 7px solid transparent;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
}
.day-title .icon-group .icon-mark {
  cursor: pointer;
  position: relative;
  z-index: 5;
  width: 3rem;
  height: 3rem;
  display: inline-block;
}
.day-title .icon-smile {
  position: relative;
  z-index: 4;
  fill: #00a3d5;
  width: 26px;
  height: 26px;
  cursor: pointer;
}
.day-title .icon-smile-bg {
  position: absolute;
  display: none;
}
.day-title .icon-smile-bg:before {
  content: "";
  width: 4rem;
  height: 4rem;
  border-radius: 100vmax;
  background-color: #efefef;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.day-title .icon-look {
  fill: rgba(0, 51, 169, 0.794);
  width: 34px;
  height: 34px;
}
.day-title .icon-hart {
  fill: red;
  width: 30px;
  height: 30px;
}
.day-title .icon-goodjob {
  fill: #000ea9;
  width: 30px;
  height: 30px;
}
.day-title .icon-fire {
  fill: #ff4800;
  width: 34px;
  height: 34px;
}

@media screen and (max-width: 520px) {
  .day-title .icon-group {
    left: 0px;
  }
  .day-title .icon-group::before {
    left: 8%;
  }
  .day-title .icon-checked-wrap {
    display: flex;
    padding-left: 0;
  }
}
/* 目標管理シートサイドナビ */
#side-navi {
  display: none;
}

.main:has(#seet-grow.active) #side-navi, .main:has(#tablinks-month.active) #side-navi {
  display: block;
  position: fixed;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  z-index: 100;
  transition: all 1s ease;
  -webkit-animation: fadeEffect 0.6s ease;
          animation: fadeEffect 0.6s ease;
}
.main:has(#seet-grow.active) #side-navi ul, .main:has(#tablinks-month.active) #side-navi ul {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.main:has(#seet-grow.active) #side-navi ul li, .main:has(#tablinks-month.active) #side-navi ul li {
  width: 30px;
  text-align: center;
  border-radius: 5px 0 0 5px;
}
.main:has(#seet-grow.active) #side-navi ul li a, .main:has(#tablinks-month.active) #side-navi ul li a {
  display: block;
  color: #fff;
  font-weight: bold;
  padding: 16px 0;
}

/* STEP tab */
.step-tab-container {
  margin-bottom: 20px;
}
.step-tab-container button.color-white {
  color: #fff !important;
}

.step-tab-header > div:first-of-type {
  display: flex;
}
.step-tab-header > div:first-of-type h3 {
  margin-bottom: 0;
  margin-right: 1em;
  display: inline-flex;
  align-items: center;
}

.step-tab-btn {
  padding: 0 0.5em;
  border-width: 1px 1px 2px 1px;
  font-size: 1.2rem;
}
.step-tab-btn span {
  font-size: 1rem;
  margin-right: 0.2em;
}

.step-tab-btn-avtive button {
  margin-bottom: -1px;
}
.step-tab-btn-avtive button.step-tab-btn-active-on {
  border: 1px solid #000;
  border-bottom: 1px solid #fff !important;
  background-color: #fff !important;
}
.step-tab-btn-avtive button:not(.step-tab-btn-active-on) {
  border: none;
}

.step-tab-content {
  display: none;
  border: 1px solid #000;
}
.step-tab-content p {
  display: flex;
}
.step-tab-content p span {
  display: block;
}
.step-tab-content p span:first-of-type {
  font-weight: bold;
  white-space: nowrap;
}

.step-tab-content-active {
  display: block;
  padding: 1.6rem 1.6rem 0;
}

@media screen and (max-width: 800px) {
  .step-tab-header > div:first-of-type {
    flex-direction: column;
  }
  .step-tab-header > div:first-of-type h3 {
    margin-bottom: 20px;
  }
}
@media screen and (max-width: 512px) {
  .step-tab-btn {
    font-size: 14px;
    line-height: 26px;
  }

  .step-tab-container p {
    font-size: 14px;
    line-height: 26px;
  }
}
/* STEP達成度 */
.step-arrow {
  display: inline-block;
  vertical-align: middle;
  width: 100px;
  height: auto;
}

table.default tr td:has(> span.step-view) {
  position: relative;
}

.step-view {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 2px 5px;
  line-height: 1;
  color: #fff;
  font-size: 9px;
  font-weight: bold;
  letter-spacing: 2;
}

.step-info-wrap {
  margin-bottom: 20px;
  margin-right: 0;
  margin-left: auto;
  white-space: nowrap;
}
.step-info-wrap span {
  color: #aaa;
  border: 1px solid #aaa;
  padding: 4px 6px;
}

.comp-bg-color {
  background-color: #FFFED6;
}
.comp-bg-color.icon-star {
  background: url("/image/ico_star.svg") no-repeat 10px center #FFFED6;
  background-size: 40px;
}

.group:has(> .complete-overlay-image) {
  position: relative;
}

.complete-overlay-image {
  position: absolute;
  top: 20%;
  left: 50%;
  transform: translateX(-50%);
  filter: opacity(0.8);
  max-width: 25%;
}

.comp-wrap {
  float: right;
}
.comp-wrap .comp span {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 80px;
  margin-right: 4px;
  font-weight: bold;
  line-height: 1.5;
  color: #fff;
  border-radius: 5px;
}
.comp-wrap .comp.comp-edit {
  display: none;
}
.comp-wrap .comp.comp-edit input {
  display: none;
}
.comp-wrap .comp.comp-edit label {
  border-radius: 50px;
  display: inline-block;
  padding: 4px 16px;
  line-height: 1;
  font-size: 1.6rem;
  font-weight: bold;
  border-radius: 50px;
  color: #11B4D9;
  border: 1px solid #11B4D9;
}
.comp-wrap .comp.comp-edit label:hover {
  color: #fff;
  background: #11B4D9;
}
.comp-wrap .comp.comp-edit input:checked + .comp-btn-radio {
  background-color: #11B4D9;
  color: white;
}
.comp-wrap .comp-edit {
  display: none;
}

.editMode .comp-wrap .comp-edit {
  display: inline-block;
}
.editMode .comp-wrap .comp + .comp {
  display: none;
}
.editMode .comp-wrap .comp-cancel-btn {
  font-size: 1.2rem;
  border: 1px solid;
  border-radius: 30px;
  padding: 0 0.5em;
  background: #f5f5f5;
  height: 25px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.editMode .comp-wrap .comp-cancel-btn:hover {
  color: #fff;
  background: #6a6a6a;
  border-color: #000;
}

@media screen and (max-width: 620px) {
  .table_td:has(> .comp-wrap) {
    display: flow-root;
  }
}
@media screen and (max-width: 768px) {
  .step-title-wrap {
    flex-direction: column;
    align-items: self-start;
  }
  .step-title-wrap h3.step-title {
    margin-bottom: 4px;
  }
  .step-title-wrap .--subTitle {
    margin-left: 0;
    margin-bottom: 4px;
  }

  .step-info-wrap {
    margin-bottom: 16px;
  }
}
@media screen and (max-width: 512px) {
  .editMode .comp-wrap .comp {
    display: flex;
    justify-content: flex-end;
    flex-direction: column;
    text-align: center;
  }

  .complete-overlay-image {
    top: 15%;
    max-width: 40%;
  }

  .step-arrow {
    width: 70px;
  }

  table.default tr td:has(> span.step-view) {
    padding-top: 12px;
  }
}
/* Feedback */
table.default.feedback-area {
  border: none;
}

.feedback-wrapper {
  position: relative;
  width: 100%;
}
.feedback-wrapper.has-overflow.collapsed .feedback-indicator {
  opacity: 1;
  line-height: 1.55;
}
.feedback-wrapper.expanded .feedback-indicator {
  top: 20px;
  transform: none;
  opacity: 0.7;
}
.feedback-wrapper:not(.has-overflow) .feedback-text {
  cursor: default;
}
.feedback-wrapper:has(.date) {
  padding-bottom: 0.5em;
}

.feedback-area td:not(:last-of-type) {
  border: none;
  width: 0;
  padding: 0;
  vertical-align: middle;
}
.feedback-area td:last-child {
  position: relative;
}
.feedback-area td:last-child span.date {
  position: absolute;
  bottom: -0.5em;
  right: -1.8em;
  font-size: 11px;
  color: #666;
}

.feedback-text {
  line-height: 1.55;
  transition: all 0.3s ease;
  cursor: pointer;
}
.feedback-text.collapsed {
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
  height: 1.55em;
  padding-right: 0.5em;
}
.feedback-text.expanded {
  white-space: normal;
  word-wrap: break-word;
  height: auto;
  min-height: 1.55em;
  padding-right: 0.5em;
}

.feedback-indicator {
  position: absolute;
  right: -1em;
  top: 50%;
  transform: translateY(-50%);
  color: #11B4D9;
  font-size: 12px;
  pointer-events: none;
  transition: opacity 0.2s;
}

.editMode .feedback-area td > div.icon-wrap {
  padding-right: 40px;
}

.ai-feedback-section {
  display: none;
  border: none;
}
.ai-feedback-section td {
  border: none !important;
}

.editMode .ai-feedback-section {
  display: revert;
}

.ai-feedback-btn {
  padding: 8px 16px;
  background-color: #007bff;
  color: white;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  font-size: 13px;
  transition: background-color 0.2s;
  font-weight: 500;
}
.ai-feedback-btn:hover {
  background-color: #0056b3;
}
.ai-feedback-btn:disabled {
  background-color: #ccc;
  cursor: not-allowed;
}

.feedback-suggestions {
  margin-top: 10px;
  padding: 12px;
  background-color: #f8f9fa;
  border-radius: 4px;
  border: 1px solid #e9ecef;
  display: none;
}
.feedback-suggestions.show {
  display: block;
}
.feedback-suggestions:has(.feedback-error) .suggestion-title, .feedback-suggestions:has(.feedback-error) .close-suggestions {
  display: none;
}

.suggestion-title {
  font-weight: bold;
  margin-bottom: 8px;
  color: #495057;
  font-size: 13px;
}

.suggestion-btn {
  display: block;
  width: 100%;
  margin-bottom: 6px;
  padding: 8px 10px;
  background-color: white;
  border: 1px solid #dee2e6;
  border-radius: 3px;
  text-align: left;
  cursor: pointer;
  font-size: 12px;
  line-height: 1.3;
  transition: all 0.2s;
}
.suggestion-btn:hover {
  background-color: #e9ecef;
  border-color: #adb5bd;
}
.suggestion-btn:last-child {
  margin-bottom: 0;
}

.close-suggestions {
  margin-top: 8px;
  padding: 4px 8px;
  background-color: #6c757d;
  color: white;
  border: none;
  border-radius: 3px;
  cursor: pointer;
  font-size: 11px;
}
.close-suggestions:hover {
  background-color: #545b62;
}

.feedback-loading {
  display: none;
  align-items: center;
  margin-top: 8px;
  color: #6c757d;
  font-size: 12px;
}
.feedback-loading.show {
  display: flex;
}

.feedback-spinner {
  width: 14px;
  height: 14px;
  border: 2px solid #f3f3f3;
  border-top: 2px solid #007bff;
  border-radius: 50%;
  -webkit-animation: spin 1s linear infinite;
          animation: spin 1s linear infinite;
  margin-right: 6px;
}

.feedback-edited {
  border-color: #28a745 !important;
  background-color: #f8fff9 !important;
}

.feedback-edit-notice {
  margin-top: 5px;
  padding: 6px 10px;
  background-color: #d4edda;
  color: #155724;
  border: 1px solid #c3e6cb;
  border-radius: 3px;
  font-size: 12px;
  -webkit-animation: fadeIn 0.3s ease-in;
          animation: fadeIn 0.3s ease-in;
}

.feedback-error {
  padding: 10px;
  background-color: #f8d7da;
  border: 1px solid #f5c6cb;
  border-radius: 4px;
  color: #721c24;
}

.error-content {
  display: flex;
  align-items: center;
  gap: 8px;
}

.error-icon {
  font-size: 16px;
}

.error-text {
  flex: 1;
  font-size: 13px;
}

.retry-btn {
  padding: 4px 8px;
  background-color: #dc3545;
  color: white;
  border: none;
  border-radius: 3px;
  cursor: pointer;
  font-size: 12px;
}
.retry-btn:hover {
  background-color: #c82333;
}

.editLock {
  display: none;
}
.editLock i {
  padding-right: 0.5em;
}

.input-restricted .motivation-value > .motivation-placeholder--default {
  display: inline !important;
}
.input-restricted .motivation-value > .motivation-placeholder--editable {
  display: none !important;
}

.motivation-value > .motivation-placeholder--default {
  display: inline;
}

.editMode .input-restricted .feature {
  background-color: #FAFBFC;
}
.editMode .input-restricted table:not(.feedback-area) td {
  background-color: #FAFBFC;
}
.editMode .input-restricted textarea {
  pointer-events: none;
}
.editMode .input-restricted .editLock {
  display: block;
  position: absolute;
  right: 0;
  top: -30px;
  color: #11B4D9;
}
.editMode .input-restricted .mark-group [type=radio]:not(:checked) + label {
  display: none;
}
.editMode .input-restricted .mark-group [type=radio]:checked + label {
  cursor: default;
}
.editMode .input-restricted .clear-radios {
  display: none;
}
.editMode .input-restricted .feedback-area textarea {
  pointer-events: auto;
}
.editMode .motivation-value > .motivation-placeholder--editable {
  display: inline;
}
.editMode .motivation-value > .motivation-placeholder--default {
  display: none;
}

.motivation-group > span {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 4px 5px;
  line-height: 1;
  color: #fff;
  font-weight: bold;
  letter-spacing: 2;
  background: #11B4D9;
}

.motivation-value {
  display: flex;
  justify-content: center;
  align-items: end;
  font-size: 30px;
  font-weight: bold;
  text-align: center;
  margin-bottom: 0;
  color: #666666;
  min-height: 45.6px;
}

.slider-container {
  position: relative;
  height: 30px;
  margin: 0 10px;
}
.slider-container .slider-track {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 100%;
  height: 15px;
  background: #E2E8F0;
  border-radius: 10px;
  overflow: hidden;
}
.slider-container .slider-fill {
  height: 100%;
  background: linear-gradient(90deg, #FF6B6B 0%, #FFB547 25%, #F7B731 50%, #00D4AA 75%, #00B4D8 100%);
  transition: width 0.3s ease;
  border-radius: 10px;
}
.slider-container .slider-input {
  position: relative;
  width: 100%;
  height: 30px;
  opacity: 0;
  cursor: pointer;
  z-index: 2;
}

.motivation-labels {
  display: flex;
  justify-content: space-between;
  margin-top: 10px;
  font-size: 18px;
  color: #666666;
  padding: 0 10px;
}
.motivation-labels span {
  transition: all 0.3s ease;
  opacity: 0.4;
}
.motivation-labels span.active {
  opacity: 1;
  transform: scale(1.2);
}

.motivation-placeholder {
  font-size: 16px;
  color: #999999;
  font-weight: normal;
}
.motivation-placeholder--default, .motivation-placeholder--editable {
  display: none;
}

@media screen and (max-width: 900px) {
  .flex-col.col-3:has(.motivation-group) {
    flex-direction: column-reverse;
    gap: 0;
  }
}
@media screen and (max-width: 520px) {
  .motivation-wrap.default,
.hobbit-wrap.default {
    position: relative;
    width: 100% !important;
  }
  .motivation-wrap.default td,
.hobbit-wrap.default td {
    width: 100%;
  }

  .hobbit-wrap tr {
    flex-direction: row !important;
    height: auto !important;
  }

  .motivation-placeholder {
    font-size: 16px;
  }

  .motivation-group > span {
    font-size: 14px;
  }
}
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@-webkit-keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@media screen and (max-width: 512px) {
  .feedback-area tr:first-of-type {
    display: flex;
    flex-wrap: wrap;
  }
  .feedback-area td:nth-of-type(2) {
    display: contents;
    width: 40px;
    height: 45px;
  }
  .feedback-area td:last-of-type {
    width: 100%;
  }
  .feedback-area td:last-of-type span.date {
    bottom: 0;
  }

  .editMode .feedback-area td:first-of-type {
    width: 40px;
    height: 40px;
  }
  .editMode .feedback-area .icon-smile-bg {
    margin-top: 33px;
  }
}
.mark-group {
  display: flex;
  justify-content: space-between;
  justify-content: center;
  align-items: center;
  gap: 16px;
}
.mark-group [type=radio]:checked,
.mark-group [type=radio]:not(:checked) {
  position: absolute;
  left: -9999px;
}
.mark-group [type=radio]:checked + label,
.mark-group [type=radio]:not(:checked) + label {
  position: relative;
  cursor: pointer;
  line-height: 38px;
  display: inline-block;
  color: #000;
  font-size: 2.4rem;
  font-weight: bold;
  z-index: 2;
  width: 45px;
}
.mark-group [type=radio]:not(:checked) + label {
  color: #fff;
  display: none;
}
.mark-group [type=radio]:checked + label:before,
.mark-group [type=radio]:not(:checked) + label:before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 38px;
  height: 38px;
  border-radius: 100%;
  z-index: -1;
}
.mark-group [type=radio]:not(:checked) + label:before {
  background: none;
  border: none;
}
.mark-group [type=radio]:checked + label:after,
.mark-group [type=radio]:not(:checked) + label:after {
  content: "";
  width: 38px;
  height: 38px;
  position: absolute;
  top: 0px;
  left: -7px;
  border-radius: 100%;
  transition: all 0.2s ease;
}
@media screen and (max-width: 520px) {
  .mark-group {
    gap: 8px;
  }
  .mark-group [type=radio]:checked + label, .mark-group [type=radio]:not(:checked) + label {
    line-height: 1;
  }
}

.clear-radios {
  display: none;
}

.editMode .icon-smile-bg {
  display: block;
}
.editMode .icon-group {
  display: flex;
}
.editMode .mark-group [type=radio]:not(:checked) + label {
  color: #000000;
  display: block;
  -webkit-animation: fadeIn 0.3s ease-in 0s forwards;
          animation: fadeIn 0.3s ease-in 0s forwards;
}
.editMode .mark-group [type=radio]:checked + label {
  color: #ffffff;
}
.editMode .mark-group [type=radio]:checked + label:before {
  background: #11B4D9;
  border: 1px solid #ddd;
}
.editMode .clear-radios {
  display: block;
  position: absolute;
  right: 0;
  top: -50px;
  padding: 2px 24px;
  border-radius: 5px;
  border: 1px solid #11B4D9;
  background: #E8F2F6;
  color: #11B4D9;
}

h3.headline {
  background: #11B4D9;
  color: #fff;
  font-weight: bold;
  text-align: center;
  padding: 6px;
  margin-bottom: 1.6rem;
  letter-spacing: 4px;
}

.post-tag .tag {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: 0.1em 0.3em;
  margin-right: 4px;
  font-weight: bold;
  line-height: 1.5;
  color: #fff;
  border-radius: 5px;
}
.post-tag .tag.tag-gray {
  background: #ccc;
  color: #333;
}
.post-tag .tag.tag-yellow {
  background: #ffd700;
  color: #333;
}
.post-tag .tag.tag-green {
  background: #4caf50;
  color: #fff;
}

.evalGrid {
  display: grid;
  grid-template-columns: auto 100px 50px;
  grid-column-gap: 10px;
  overflow: auto;
  white-space: nowrap;
}
.evalGrid .col {
  padding: 10px 0;
  text-align: center;
  line-height: 1.5;
}
.evalGrid .col1 {
  padding: 10px 0;
  text-align: center;
  line-height: 1.5;
}
.evalGrid .col2 {
  flex-basis: 70%;
}
.evalGrid .col3 {
  flex-basis: 15%;
}
.evalGrid .caption {
  height: 60px;
}
.evalGrid .caption.left {
  text-align: left;
}
.evalGrid table.default {
  height: calc(100% - 60px);
}
.evalGrid table.default.eval th {
  vertical-align: middle;
}
.evalGrid table.default.eval td {
  vertical-align: middle;
}
@media screen and (max-width: 768px) {
  .evalGrid {
    grid-template-columns: 1fr;
    grid-column-gap: 0;
  }
  .evalGrid .caption {
    height: auto;
    padding-bottom: 10px;
  }
  .evalGrid table.default {
    height: auto;
  }
  .evalGrid .col {
    overflow-x: auto;
  }
}

.evalGrid2 {
  display: grid;
  grid-template-columns: auto 100px 60px;
  grid-column-gap: 10px;
  overflow: auto;
  white-space: nowrap;
  /* display: flex;
     align-items: stretch; */
}
.evalGrid2 .caption {
  height: 60px;
}
.evalGrid2 .col3 {
  line-height: 1.5;
  text-align: center;
}
.evalGrid2 .col3 .default.eval td {
  vertical-align: middle;
}
@media screen and (max-width: 768px) {
  .evalGrid2 .col3 .default.eval td {
    height: 40px !important;
  }
}

@media screen and (max-width: 768px) {
  .evalGrid {
    grid-template-columns: 1fr 1fr;
  }
  .evalGrid div:first-of-type {
    grid-column: 1/3;
  }

  .evalGrid2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  .evalGrid2 .col2 {
    grid-column: 1/3;
  }
  .evalGrid2 .caption {
    height: auto;
    padding-bottom: 10px;
  }
}
@media screen and (max-width: 520px) {
  .evalGrid table.default.perf {
    border: none;
  }
  .evalGrid table.default.perf tr {
    display: flex;
    flex-direction: column;
  }
  .evalGrid table.default.perf tr:nth-of-type(3) th {
    margin-top: 20px;
  }
  .evalGrid table.default.perf th:last-of-type {
    border-bottom: none;
  }
  .evalGrid table.default.perf td:not(:last-of-type) {
    border-top: none;
    border-bottom: none;
  }

  .evalGrid2 .caption {
    height: auto;
    padding-bottom: 10px;
    text-align: center;
  }
  .evalGrid2 .col3 .default.eval td:last-of-type {
    height: 50px !important;
  }
}
.hidden-eval-point {
  font-size: 1.4rem;
}

@media screen and (min-width: 1221px) {
  .br-disp {
    display: none;
  }
}
select {
  -moz-appearance: menulist;
  -webkit-appearance: menulist;
}

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

@media screen and (max-width: 620px) {
  .howtouse_ttl {
    font-size: 1.4rem;
  }

  .howtouse_subttl {
    font-size: 1.2rem;
  }
}
.content_ttl {
  display: flex;
  align-items: center;
}

@media screen and (max-width: 620px) {
  .content_ttl {
    display: flex;
    align-items: center;
    flex-direction: column;
  }
}
.wrap__set {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.post-title {
  display: flex;
  text-align: left;
  align-items: center;
  /* justify-content: flex-start; */
}

@media screen and (max-width: 620px) {
  .post-title {
    flex-direction: column;
  }
}
.button-container-report {
  margin-left: 20px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.button-container-report button {
  flex: 1 1 auto;
  max-width: 100%;
}

@media screen and (max-width: 620px) {
  .button-container-report {
    width: 100%;
    margin-left: 0;
    flex-direction: column;
  }

  .button-container-report button {
    width: 100%;
    text-align: center;
  }
}
.wrap__people {
  display: flex;
  flex-direction: column;
  justify-content: left;
}

.wrap_content__people {
  justify-content: left;
}

.wrap__thumbnail {
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 520px) {
  .wrap__thumbnail {
    width: 100%;
  }
}

.wrap_content1 {
  display: flex;
  align-items: center;
  margin-bottom: 1rem;
}

@media screen and (max-width: 620px) {
  .wrap_content1 .icon-image2 + .post-title {
    width: 100%;
  }
}
@media screen and (max-width: 520px) {
  .wrap_content1 .icon-image2 + .post-title {
    align-items: start;
  }

  .wrap_content {
    display: flex;
    align-items: center;
    padding-bottom: 8px;
  }
}
.input-group {
  width: 100%;
}

.custom-file {
  width: 100%;
}

.input-group {
  width: 100%;
}

.custom-file {
  width: 100%;
}

@media screen and (max-width: 620px) {
  .table_th,
.table_td {
    display: block;
    text-align: left;
  }

  .table_th {
    width: 100% !important;
  }
}
@media screen and (max-width: 520px) {
  table.default th.left {
    width: 100% !important;
    white-space: wrap !important;
  }
  table.default th.left .sel-eval-step {
    width: 100% !important;
    margin-top: 1em !important;
    margin-left: 0 !important;
  }
}
.login-option {
  display: flex;
}

.login-parts {
  margin-left: 0.5rem;
}

/* footer menu */
.footer-menu {
  display: none;
}

@media screen and (max-width: 520px) {
  .footer-menu {
    position: fixed;
    bottom: 0;
    z-index: 100;
    display: block;
    width: 100%;
    height: auto;
    padding: 0;
    background-color: #e6e6e6;
  }
  .footer-menu .footer-list {
    display: flex;
    font-size: 12px;
    text-align: center;
  }
  .footer-menu .footer-list li {
    width: 20%;
    padding-top: 8px;
    border-right: #dadada 1px solid;
  }
  .footer-menu .footer-list li div {
    padding-top: 8px;
  }
  .footer-menu .footer-list li a {
    display: block;
    height: 100%;
    line-height: 1.1;
    color: #000;
  }
  .footer-menu .footer-list svg {
    width: 20px;
    height: 20px;
  }
}
/* 研修動画 */
.content_video {
  display: none;
}
.content_video .block-txt:has(+ .post-area > .video-item) {
  border-bottom: 1px solid #000;
  padding-bottom: 1em;
}
.content_video:has(.video-item) {
  display: block;
}
.content_video:has(.report-content) {
  display: block;
}
.content_video .side-icon {
  display: inline-block;
  width: 20px;
  height: 24px;
  fill: #12b4d9;
  vertical-align: middle;
  margin-right: 0.5em;
  padding-top: 4px;
}

.video-item .video {
  margin: 1em 0 1.8em;
}
.video-item .status-btn {
  padding: 8px 15px;
  border: 1px solid #ccc;
  background-color: #fff;
  cursor: pointer;
  margin: 2px;
}
.video-item .status-btn.active {
  background: #11B4D9;
  color: #fff;
}
.video-item .view-status {
  padding-bottom: 1em;
  width: 100%;
  max-width: 900px;
}
.video-item .view-status .status {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  padding: 1em;
  background: #E8F2F6;
  border-bottom-width: 1px;
}
.video-item .view-status .status span {
  padding-right: 1em;
}
.video-item .view-status .report {
  padding: 1em;
  background-color: rgba(246, 246, 246, 0.6);
}
.video-item textarea {
  width: 100%;
  height: 200px;
  margin-bottom: 0.8em;
  background-color: #fff;
}
.video-item textarea + button {
  margin-left: auto;
  margin-right: 0;
  display: block;
  background-color: #fff;
}
.video-item iframe, .video-item video {
  width: 100%;
  max-width: 900px;
  aspect-ratio: 16/9;
}

.video-status-table {
  width: 100%;
  border-top: 1px solid #11b4d9;
  border-collapse: collapse;
  margin-top: 10px;
}

.video-status-table th, .video-status-table td {
  border-bottom: 1px solid #11b4d9;
  padding: 8px;
  text-align: left;
}

.video-status-table th {
  background-color: #E8F2F6;
  color: #11b4d9 !important;
}
.video-status-table th:first-of-type {
  width: 25%;
}
.video-status-table th:nth-of-type(2) {
  width: 10%;
  white-space: nowrap;
}
.video-status-table th:last-of-type {
  width: auto;
}

.video-status-table td.report-content {
  position: relative;
  padding-bottom: 1.8em;
}

.report-date {
  position: absolute;
  right: 10px;
  bottom: 5px;
  font-size: 12px;
  color: #777;
}

.video-wrapper {
  position: relative;
  display: inline-block;
  cursor: pointer;
  width: 100%;
  max-width: 900px;
  aspect-ratio: 16/9;
}

.video-thumbnail {
  width: 100%;
  height: auto;
  display: block;
}

.play-button {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: rgba(0, 0, 0, 0.6);
  color: white;
  font-size: 24px;
  padding: 10px 20px;
  border-radius: 50%;
}

@media screen and (max-width: 520px) {
  .content_video {
    padding: 2.5%;
  }

  .video-item textarea {
    height: 150px;
  }
  .video-item .video {
    margin: 0.8em 0 1em;
  }

  .video-status-table th {
    display: none;
  }
  .video-status-table tr {
    border: #11b4d9 2px solid !important;
  }
  .video-status-table td {
    display: block;
    width: 100% !important;
    min-height: 42.8px;
    border: none;
  }
  .video-status-table td:first-of-type {
    background-color: #E8F2F6;
    border-bottom: #11b4d9 1px solid !important;
    color: #11b4d9 !important;
    font-weight: bold;
    text-align: center;
  }
  .video-status-table td:not(:first-of-type)::before {
    color: #11b4d9 !important;
    content: attr(data-label);
    font-weight: bold;
    padding: 0px 10px;
    display: inline;
    border: #11b4d9 1px solid !important;
    margin-right: 10px;
    float: left;
  }
}
/* ダッシュボード */
.card {
  background: #fff;
  padding: 0;
  overflow: hidden;
}
.card i {
  color: #11B4D9;
  transition: all ease 0.2s;
}
.card a:hover i {
  color: white;
}
.card-header {
  padding: 24px 28px;
  border-bottom: 1px solid #e2e8f0;
  background: linear-gradient(to right, #FAFBFC, #FFFFFF);
}
@media screen and (max-width: 520px) {
  .card-header {
    padding: 16px 20px;
  }
}
.card-title {
  font-size: 18px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 0;
}
@media screen and (max-width: 520px) {
  .card-title {
    font-size: 1.7rem;
  }
}
.card-body {
  padding: 28px;
}

.step-title {
  font-weight: bold;
  margin: 12px 0 4px;
}

.bar {
  width: 30px;
  height: 15px;
  border-radius: 4px;
  cursor: pointer;
}
.bar-container {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 16px;
}

.staff-section-header {
  margin-bottom: 32px;
}
.staff-section-title {
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 8px;
}
.staff-section-subtitle {
  font-size: 16px;
}

.staff-top-info-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-bottom: 32px;
}

.staff-main-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  margin-bottom: 32px;
}

.staff-three-column-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.staff-three-column-grid:has(.card:nth-child(2):last-child) {
  grid-template-columns: repeat(2, 1fr);
}

@media screen and (max-width: 1200px) {
  .staff-top-info-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .staff-top-info-grid div:first-of-type {
    order: 1;
  }
  .staff-top-info-grid div:nth-of-type(2) {
    order: 3;
  }
  .staff-top-info-grid div:nth-of-type(3) {
    order: 4;
  }
  .staff-top-info-grid div:last-of-type {
    order: 2;
  }

  .staff-three-column-grid {
    grid-template-columns: 1fr;
  }
  .staff-three-column-grid:has(.card:nth-child(2):last-child) {
    grid-template-columns: 1fr;
  }
}
@media screen and (max-width: 520px) {
  .staff-top-info-grid {
    grid-template-columns: 1fr;
  }

  .main section:last-of-type.staff-three-column-grid {
    margin-bottom: 60px;
  }
}
.staff-info-card {
  background: #fff;
  padding: 20px;
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  gap: 16px;
}
.staff-info-card.profile {
  grid-column: span 1;
}
.staff-info-card.metric {
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
}
.staff-info-card.cta {
  background: #11B4D9;
  color: white;
}
.staff-info-card.cta .btn.primary.btn-to-daily {
  background-color: #fff;
}
.staff-info-card.cta .btn.primary.btn-to-daily:hover {
  color: #11B4D9;
  background-color: #E8F4FD;
}

.staff-profile-avatar {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: linear-gradient(135deg, #667eea, #764ba2);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  font-weight: 700;
  flex-shrink: 0;
}
.staff-profile-info {
  flex: 1;
}
.staff-profile-dept {
  font-size: 14px;
  margin-bottom: 4px;
}
.staff-profile-name {
  font-size: 16px;
  font-weight: 600;
}

.staff-metric-label {
  font-size: 16px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
}
.staff-metric-label i {
  color: #11B4D9;
  font-size: 18px;
}
.staff-metric-value {
  font-size: 28px;
  font-weight: 700;
  color: #11B4D9;
}
.staff-metric-sub {
  font-size: 13px;
  color: #3db7b7;
  font-weight: 500;
}

.staff-cta-text {
  font-size: 15px;
  font-weight: 600;
  padding-bottom: 20px;
}
.staff-cta-button {
  background: white;
  color: #11B4D9;
  border: none;
  padding: 8px 20px;
  border-radius: 20px;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  margin-top: 8px;
}

.staff-tab-buttons {
  display: flex;
  gap: 0;
  border-bottom: 2px solid #e2e8f0;
  margin-bottom: 24px;
}
.staff-tab-button {
  flex: 1;
  padding: 12px 16px;
  border: none;
  background: none;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  position: relative;
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.staff-tab-button.active {
  color: #11B4D9;
}
.staff-tab-button.active::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  right: 0;
  height: 2px;
  background: #11B4D9;
}
.staff-tab-badge {
  display: inline-block;
  background: red;
  color: white;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 600;
}

.staff-notification-list {
  max-height: 240px;
  overflow-y: auto;
  padding-right: 4px;
}
.staff-notification-item {
  margin: 8px 0;
  padding: 8px 4px;
  border-bottom: 1px solid #e2e8f0;
  cursor: pointer;
  transition: all 0.2s ease;
}
.staff-notification-item.unread {
  background-color: #fcf8e5;
}
.staff-notification-title {
  font-weight: 600;
  margin-bottom: 4px;
  color: var(--text-primary);
  font-size: 15px;
}
.staff-notification-date {
  font-size: 13px;
  color: #343A40;
}

.staff-step-progress-container:not(:last-of-type) {
  margin-bottom: 28px;
}
.staff-step-header {
  display: flex;
  justify-content: space-between;
  margin-bottom: 12px;
  font-size: 14px;
}
.staff-step-label {
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 8px;
}
.staff-step-label span {
  white-space: nowrap;
}
.staff-step-label a {
  word-break: break-all;
}
.staff-step-progress {
  display: flex;
  gap: 4px;
  height: 32px;
  background: #f8fafb;
  border-radius: 8px;
  padding: 4px;
  position: relative;
}
.staff-step-item {
  flex: 1;
  background: #E2E8F0;
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.3s ease;
}
.staff-step-item.completed {
  background: #3db7b7;
}
.staff-step-item.partial-33 {
  background: linear-gradient(to right, #FFC107 33%, #E2E8F0 33%);
}
.staff-step-item.partial-66 {
  background: linear-gradient(to right, #11B4D9 66%, #E2E8F0 66%);
}
.staff-step-item:hover .staff-step-tooltip {
  opacity: 1;
}
.staff-step-item:first-of-type .staff-step-tooltip {
  left: 0;
}
.staff-step-item:first-of-type .staff-step-tooltip::after {
  left: 16.6666666667%;
}
.staff-step-item:nth-of-type(2) .staff-step-tooltip {
  left: 50%;
  transform: translateX(-50%);
}
.staff-step-item:nth-of-type(2) .staff-step-tooltip::after {
  left: 50%;
  transform: translateX(-50%);
}
.staff-step-item:last-of-type .staff-step-tooltip {
  right: 0;
}
.staff-step-item:last-of-type .staff-step-tooltip::after {
  right: 16.6666666667%;
}
.staff-step-tooltip {
  position: absolute;
  bottom: 100%;
  left: 0;
  background: #000;
  color: white;
  padding: 6px 10px;
  border-radius: 6px;
  font-size: 12px;
  opacity: 0;
  pointer-events: none;
  margin-bottom: 4px;
  width: 100%;
}
.staff-step-tooltip::after {
  content: "";
  position: absolute;
  top: 100%;
  width: 0;
  height: 0;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-top: 6px solid #000;
}

.staff-score-info {
  text-align: center;
  margin-top: 20px;
}
.staff-score-chart-container {
  position: relative;
}
.staff-score-change {
  font-size: 16px;
  font-weight: 600;
  color: #3db7b7;
}

.staff-training-progress {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  margin: 20px 0;
}
@media screen and (max-width: 520px) {
  .staff-training-progress {
    flex-direction: column;
    margin: 0;
  }
}
.staff-training-info {
  flex: 1;
}
.staff-training-info .all-watched-message {
  font-size: 16px;
  font-weight: 600;
  color: #3db7b7;
}
.staff-training-stats {
  font-size: 14px;
  color: #343A40;
  margin-bottom: 12px;
}
.staff-training-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.staff-training-list li {
  padding: 4px 0;
  font-size: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.staff-circular-progress {
  position: relative;
  width: 120px;
  height: 120px;
}

.staff-progress-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
}
.staff-progress-value {
  font-size: 28px;
  font-weight: 700;
  color: #11B4D9;
}
.staff-progress-label {
  font-size: 12px;
  color: #343A40;
}

#noDataMessage {
  text-align: center;
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.5);
  display: inline-flex;
  justify-content: center;
  align-items: center;
}

.evaluator-area .btn-to-daily {
  min-width: 100px;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  padding: 1.2rem 1rem;
}
@media screen and (max-width: 1100px) {
  .evaluator-area .btn-to-daily {
    margin-top: 6px;
  }
}
@media screen and (max-width: 520px) {
  .evaluator-area {
    margin-bottom: 60px;
  }
}

i.fa.fa-exclamation {
  color: #FFC107;
}

.member-table-modern {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  padding: 20px;
}
.member-table-modern thead {
  background: #F8F9FA;
}
.member-table-modern th {
  padding: 16px 20px;
  text-align: left;
  font-weight: 600;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: 2px solid #e2e8f0;
}
.member-table-modern th:first-child {
  border-radius: 12px 0 0 0;
}
.member-table-modern td {
  padding: 20px;
  font-size: 14px;
}
.member-table-modern td:has(i) {
  padding-left: 0;
}
.member-table-modern td:first-of-type {
  max-width: 300px;
}
@media screen and (max-width: 1100px) {
  .member-table-modern thead {
    display: none;
  }
  .member-table-modern th {
    display: block;
  }
  .member-table-modern tr {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
  .member-table-modern tr:not(:first-of-type) {
    padding-top: 20px;
  }
  .member-table-modern tr:not(:last-of-type) {
    border-bottom: 1px solid #e2e8f0;
  }
  .member-table-modern td {
    display: block;
    position: relative;
  }
  .member-table-modern td::before {
    content: attr(data-label);
    position: absolute;
    top: 0;
    left: 20px;
    color: #718096;
  }
}
@media screen and (max-width: 520px) {
  .member-table-modern tr {
    grid-template-columns: 1fr;
  }
  .member-table-modern tr:not(:first-of-type) {
    padding-top: 8px;
  }
  .member-table-modern td {
    padding: 8px 20px 8px 120px;
  }
  .member-table-modern td:first-of-type {
    padding-left: 50px;
    max-width: none;
  }
  .member-table-modern td:first-of-type:not(:has(i)) {
    padding-left: 69px;
  }
  .member-table-modern td::before {
    top: 50%;
    left: 0;
    transform: translate(0, -50%);
  }
}
.member-info-modern {
  display: flex;
  align-items: center;
  gap: 12px;
}
.member-details-modern {
  display: flex;
  flex-direction: column;
}
.member-name-modern {
  font-weight: 600;
}
.member-login-modern {
  font-size: 12px;
  color: #718096;
}
.member-login-modern span {
  white-space: nowrap;
}

.avatar-modern {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 16px;
  color: white;
  flex-shrink: 0;
}

.percentage-modern {
  font-weight: 600;
  font-size: 15px;
}

.motivation-wrap {
  position: relative;
}
.motivation-modern {
  display: flex;
  align-items: center;
  gap: 8px;
}
.motivation-modern .percentage-modern {
  min-width: 48px;
  text-align: center;
}
@media screen and (max-width: 1100px) {
  .motivation-modern .percentage-modern {
    min-width: auto;
  }
}
.motivation-bar-modern {
  width: 60px;
  height: 6px;
  background: #ccc;
  border-radius: 3px;
  overflow: hidden;
  position: relative;
}
.motivation-fill-modern {
  height: 100%;
  border-radius: 3px;
  transition: width 0.3s ease;
}

.desc_rate .percentage-modern {
  min-width: 48px;
  text-align: center;
  display: inline-block;
}
@media screen and (max-width: 520px) {
  .desc_rate .percentage-modern {
    min-width: auto;
  }
}

.contentWrap.logout input[type=email],
.contentWrap.logout input[type=password] {
  width: 100%;
}

.icon--bell span.none {
  display: none;
}

header .logo img {
  width: 230px;
}
@media only screen and (max-width: 768px) {
  header .logo img {
    width: 40px;
  }
}

.box .block-ttl {
  font-size: 2rem;
}
@media screen and (max-width: 520px) {
  .box .block-ttl {
    font-size: 1.7rem;
  }
}
.box .post-area .post-item .post-date {
  width: auto;
}

.form-report input[type=text] {
  width: 100%;
  padding: 0;
  border: none;
  outline: none;
}
.form-report textarea {
  width: 100%;
  padding: 0;
  border: none;
  outline: none;
  resize: none;
}
@media screen and (max-width: 520px) {
  .form-report {
    overflow-x: hidden;
  }
}

main .box {
  position: relative;
  max-width: 100%;
  min-width: 100%;
}
main .box .sort-area .btn-new {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}

.evalGrid table.default.eval td select {
  padding: 0 !important;
}

#calendar-card {
  background-color: #ffffff;
}
#calendar-card .card-body .fc {
  margin-top: 5px;
}
#calendar-card .card-body .fc .fc-header-toolbar {
  margin-bottom: 1.5rem;
  padding: 1rem;
}
#calendar-card .card-body .fc .fc-header-toolbar .fc-toolbar-chunk {
  display: flex;
}
#calendar-card .card-body .fc .fc-header-toolbar .fc-toolbar-chunk .btn-group {
  position: relative;
  display: flex;
  vertical-align: middle;
}
#calendar-card .card-body .fc .fc-header-toolbar .fc-toolbar-chunk .btn-group .fc-prev-button {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
#calendar-card .card-body .fc .fc-header-toolbar .fc-toolbar-chunk .btn-group .fc-next-button {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
#calendar-card .card-body .fc .fc-header-toolbar .fc-toolbar-chunk .btn {
  display: inline-block;
}
#calendar-card .card-body .fc .fc-header-toolbar .fc-toolbar-chunk .btn.disabled, #calendar-card .card-body .fc .fc-header-toolbar .fc-toolbar-chunk .btn:disabled {
  opacity: 0.65;
  box-shadow: none;
}
#calendar-card .card-body .fc .fc-header-toolbar .fc-toolbar-chunk .btn:hover {
  opacity: 0.8;
}
#calendar-card .card-body .fc .fc-header-toolbar .fc-toolbar-chunk .btn-primary {
  color: #fff;
  background-color: #007bff;
  border-color: #007bff;
  box-shadow: none;
}
#calendar-card .card-body .fc .fc-view-harness .fc-scrollgrid-liquid th, #calendar-card .card-body .fc .fc-view-harness .fc-scrollgrid-liquid td {
  border: 1px solid #dee2e6;
}
#calendar-card .card-body .fc-direction-ltr {
  direction: ltr;
  text-align: left;
}

.mypage input[type=text], .mypage input[type=email], .mypage input[type=password] {
  width: 100%;
  padding: 0;
  border: none;
  outline: none;
}
.mypage textarea {
  width: 100%;
  padding: 0;
  border: none;
  outline: none;
  resize: none;
}
.mypage table.default {
  margin: 0 0 30px;
}
.mypage table tr td {
  position: relative;
}
.mypage table tr td .error {
  position: absolute;
  left: 12px;
  bottom: -20px;
  font-size: 10px;
  font-weight: normal;
  color: red;
}
