@charset "UTF-8";
/*****************************************************************
 VARIABLE
*****************************************************************/
/*****************************************************************
 FIELD
*****************************************************************/
button,
input,
select,
textarea {
  position: relative;
  background: none;
  color: #333333;
  overflow: visible;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  transition: all 0.1s ease-out;
  font-weight: 300;
  text-align: left;
  text-decoration: none;
  outline: none;
  border: none;
  margin: 0.25rem 0;
}
button:focus,
input:focus,
select:focus,
textarea:focus {
  outline: none;
}
select {
  background-image: url(../img/baseline-expand_more-24px.svg);
  background-size: 1.5rem;
  background-position: right 0.5rem center;
  background-repeat: no-repeat;
}
input[type="text"],
input[type="file"],
input[type="password"],
select,
textarea,
p.lace,
.error {
  display: inline-block;
  width: 100%;
  border-radius: 0.5rem;
  padding: 0.25rem 0.75rem;
  background-color: #ecede8;
  border: solid 0.125rem #737373;
  color: #333333;
  font-weight: 300;
}
input[type="text"]:focus,
input[type="file"]:focus,
input[type="password"]:focus,
select:focus,
textarea:focus,
p.lace:focus,
.error:focus {
  border-color: #b3b3b3;
  background-color: #ffffff;
}
input[type="text"]:disabled,
input[type="file"]:disabled,
input[type="password"]:disabled,
select:disabled,
textarea:disabled,
p.lace:disabled,
.error:disabled {
  border-color: #aaaaaa;
}
input[type="text"].s,
input[type="file"].s,
input[type="password"].s,
select.s,
textarea.s,
p.lace.s,
.error.s {
  width: 9.5rem;
}
@media screen and (max-width: 799px) {
  input[type="text"].s,
  input[type="file"].s,
  input[type="password"].s,
  select.s,
  textarea.s,
  p.lace.s,
  .error.s {
    min-width: 7.5rem;
  }
}
input[type="text"].ss,
input[type="file"].ss,
input[type="password"].ss,
select.ss,
textarea.ss,
p.lace.ss,
.error.ss {
  min-width: 0;
}
input[type="text"].year,
input[type="file"].year,
input[type="password"].year,
select.year,
textarea.year,
p.lace.year,
.error.year {
  width: 6.5rem;
}
input[type="text"].month,
input[type="file"].month,
input[type="password"].month,
select.month,
textarea.month,
p.lace.month,
.error.month {
  width: 5rem;
}
textarea {
  min-height: 2.4rem;
}
@media screen and (max-width: 799px) {
  textarea {
    min-height: 2.2rem;
  }
}
input[type="text"],
input[type="file"],
input[type="password"],
select,
textarea,
p.lace,
.error,
p.note .selection {
  min-height: 2.2rem;
  padding: 0.25rem 0.75rem;
}
@media screen and (max-width: 799px) {
  input[type="text"],
  input[type="file"],
  input[type="password"],
  select,
  textarea,
  p.lace,
  .error,
  p.note .selection {
    min-height: 2rem;
    line-height: 1.15rem;
  }
}
input[type="text"] + input[type="text"],
input[type="text"] + input[type="file"],
input[type="text"] + input[type="password"],
input[type="text"] + select,
input[type="text"] + textarea,
input[type="text"] + p.lace,
input[type="text"] + .error,
input[type="text"] + p.note .selection,
input[type="file"] + input[type="text"],
input[type="file"] + input[type="file"],
input[type="file"] + input[type="password"],
input[type="file"] + select,
input[type="file"] + textarea,
input[type="file"] + p.lace,
input[type="file"] + .error,
input[type="file"] + p.note .selection,
input[type="password"] + input[type="text"],
input[type="password"] + input[type="file"],
input[type="password"] + input[type="password"],
input[type="password"] + select,
input[type="password"] + textarea,
input[type="password"] + p.lace,
input[type="password"] + .error,
input[type="password"] + p.note .selection,
select + input[type="text"],
select + input[type="file"],
select + input[type="password"],
select + select,
select + textarea,
select + p.lace,
select + .error,
select + p.note .selection,
textarea + input[type="text"],
textarea + input[type="file"],
textarea + input[type="password"],
textarea + select,
textarea + textarea,
textarea + p.lace,
textarea + .error,
textarea + p.note .selection,
p.lace + input[type="text"],
p.lace + input[type="file"],
p.lace + input[type="password"],
p.lace + select,
p.lace + textarea,
p.lace + p.lace,
p.lace + .error,
p.lace + p.note .selection,
.error + input[type="text"],
.error + input[type="file"],
.error + input[type="password"],
.error + select,
.error + textarea,
.error + p.lace,
.error + .error,
.error + p.note .selection,
p.note .selection + input[type="text"],
p.note .selection + input[type="file"],
p.note .selection + input[type="password"],
p.note .selection + select,
p.note .selection + textarea,
p.note .selection + p.lace,
p.note .selection + .error,
p.note .selection + p.note .selection {
  margin: 0.5rem 0;
}
p.lace,
.error,
p.note {
  line-height: 1.65rem;
  border: none;
  margin-top: 0;
  border-radius: 0.5rem;
  font-size: 0.925rem;
}
p.note {
  color: #ffffff;
}
p.note::before {
  content: "※";
  display: inline-block;
  margin-right: 0.5rem;
}
p.lace {
  background-color: #aaaaaa;
}
p.lace.ss {
  min-width: 0;
  width: auto;
}
.error {
  color: #c10303;
}
input[type="radio"],
input[type="checkbox"] {
  display: none;
  margin: 0;
  padding: 0;
}
input[type="radio"]:checked + label.btn,
input[type="checkbox"]:checked + label.btn {
  background-color: #903434;
}
input[type="file"] {
  display: none;
}
label.check,
label.radio {
  position: relative;
  margin: 0.2rem 0.5rem 0.2rem 0;
  text-align: left;
}
label.check input[type="checkbox"] + span,
label.radio input[type="checkbox"] + span,
label.check input[type="radio"] + span,
label.radio input[type="radio"] + span {
  padding-left: 2rem;
  display: inline-block;
}
label.check input[type="checkbox"] + span::before,
label.radio input[type="checkbox"] + span::before,
label.check input[type="radio"] + span::before,
label.radio input[type="radio"] + span::before,
label.check input[type="checkbox"] + span::after,
label.radio input[type="checkbox"] + span::after,
label.check input[type="radio"] + span::after,
label.radio input[type="radio"] + span::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto 0;
  transition: all 0.1s ease-out;
}
label.check input[type="checkbox"] + span::before,
label.radio input[type="checkbox"] + span::before,
label.check input[type="radio"] + span::before,
label.radio input[type="radio"] + span::before {
  width: 1.25rem;
  height: 1.25rem;
  left: 0.2rem;
  background-color: #ecede8;
  border: solid 0.125rem #737373;
}
label.check input[type="checkbox"] + span::after,
label.radio input[type="checkbox"] + span::after,
label.check input[type="radio"] + span::after,
label.radio input[type="radio"] + span::after {
  opacity: 0;
}
label.check input[type="checkbox"]:checked + span::before,
label.radio input[type="checkbox"]:checked + span::before,
label.check input[type="radio"]:checked + span::before,
label.radio input[type="radio"]:checked + span::before {
  border-color: #b3b3b3;
  background-color: #ffffff;
}
label.check input[type="checkbox"]:checked + span::after,
label.radio input[type="checkbox"]:checked + span::after,
label.check input[type="radio"]:checked + span::after,
label.radio input[type="radio"]:checked + span::after {
  opacity: 1;
}
label.check input[type="checkbox"]:disabled + span::before,
label.radio input[type="checkbox"]:disabled + span::before,
label.check input[type="radio"]:disabled + span::before,
label.radio input[type="radio"]:disabled + span::before {
  border-color: #aaaaaa;
}
label.check.on span::after,
label.radio.on span::after {
  opacity: 1;
}
label.check span::before {
  border-radius: 0.2rem;
}
label.check span::after {
  border: solid 0.25rem #346e65;
  border-right: none;
  border-top: none;
  transform: rotate(-55deg) translateY(-0.25rem);
  width: 1rem;
  height: 0.75rem;
  left: 0.5rem;
}
label.radio span::before {
  border-radius: 50%;
}
label.radio span::after {
  width: 0.5rem;
  height: 0.5rem;
  border: solid 0.35rem #346e65;
  border-radius: 50%;
  left: 0.5rem;
}
.selection > label {
  display: inline-block;
}
@media screen and (max-width: 799px) {
  .selection > label {
    width: 100%;
  }
}
.field {
  display: block;
  left: 0;
  right: 0;
  margin: 0 auto 1rem auto;
}
@media screen and (min-width: 1280px) {
  .field {
    width: 90%;
  }
}
.field-title {
  padding: 0.25rem 0 0.25rem;
  margin-bottom: 0.25rem;
  border-bottom: solid 1px #aaaaaa;
  position: relative;
  z-index: 1;
}
.field-title > * {
  vertical-align: middle;
}
.field-title::before,
.field-title::after {
  content: "";
  display: inline-block;
  width: 1.15rem;
  height: 1.5rem;
  margin: 0 0.25rem;
  background-image: url(../img/gem_gold.png);
  background-position: center;
  background-size: 0.925rem;
  vertical-align: middle;
}
@media screen and (min-width: 800px) {
  .field-title::after {
    display: none;
  }
}
.field-title .btn {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 0.8125rem;
}
.field.star {
  display: block;
  width: 100%;
  border-radius: 0.5rem;
  padding: 0.25rem 0.75rem;
  border: solid 0.125rem #b3b3b3;
  background-color: #4e483e;
}
@media screen and (min-width: 800px) {
  .field.star {
    width: 48.5%;
  }
  .field.star:nth-child(2n -1) {
    float: left;
  }
  .field.star:nth-child(2n) {
    margin-left: 51.5%;
  }
}
.star {
  text-align: right;
}
.star-lower,
.star-upper,
.star-title {
  display: inline-block;
  vertical-align: middle;
  height: 1.5rem;
}
.star-lower,
.star-upper {
  min-width: 3rem;
  line-height: 1.35rem;
  margin: 0 0.25rem;
  text-align: center;
}
.star-title {
  width: 100%;
  text-align: left;
  margin-bottom: 0.25rem;
  line-height: 1.5rem;
}
@media screen and (min-width: 1280px) {
  .star-title {
    width: auto;
    float: left;
    margin-bottom: 0;
  }
}
.star-chip {
  display: inline-block;
  vertical-align: middle;
  height: 1.5rem;
  line-height: 1.35rem;
}
.star-chip label {
  display: inline-block;
  height: 1.5rem;
  width: 1.5rem;
  position: relative;
  text-align: center;
}
.star-chip label::before,
.star-chip label::after {
  display: inline-block;
  font-family: "Font Awesome 5 Free";
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  font-size: 1.25rem;
  text-align: center;
}
.star-chip label::before {
  content: "\f005";
  color: #595959;
  font-weight: 900;
  transition: color ease 0.5s;
  z-index: 1;
}
.star-chip label::after {
  content: "\f005";
  color: #caa846;
  font-weight: 400;
  z-index: 2;
}
.star-chip label.clear::before {
  content: "\f00d";
  color: #ffffff;
  font-size: 1.5rem;
  margin-top: 0.125rem;
  text-shadow: none;
}
.star-chip label.clear::after {
  display: none;
}
.star-chip label.on::before {
  color: #caa846;
}
.star input[type="radio"][value="1"]:checked ~ .star-chip label:nth-child(2)::before {
  color: #caa846;
}
.star input[type="radio"][value="2"]:checked ~ .star-chip label:nth-child(2)::before,
.star input[type="radio"][value="2"]:checked ~ .star-chip label:nth-child(3)::before {
  color: #caa846;
}
.star input[type="radio"][value="3"]:checked ~ .star-chip label:nth-child(2)::before,
.star input[type="radio"][value="3"]:checked ~ .star-chip label:nth-child(3)::before,
.star input[type="radio"][value="3"]:checked ~ .star-chip label:nth-child(4)::before {
  color: #caa846;
}
.star input[type="radio"][value="4"]:checked ~ .star-chip label:nth-child(2)::before,
.star input[type="radio"][value="4"]:checked ~ .star-chip label:nth-child(3)::before,
.star input[type="radio"][value="4"]:checked ~ .star-chip label:nth-child(4)::before,
.star input[type="radio"][value="4"]:checked ~ .star-chip label:nth-child(5)::before {
  color: #caa846;
}
.star input[type="radio"][value="5"]:checked ~ .star-chip label:nth-child(2)::before,
.star input[type="radio"][value="5"]:checked ~ .star-chip label:nth-child(3)::before,
.star input[type="radio"][value="5"]:checked ~ .star-chip label:nth-child(4)::before,
.star input[type="radio"][value="5"]:checked ~ .star-chip label:nth-child(5)::before,
.star input[type="radio"][value="5"]:checked ~ .star-chip label:nth-child(6)::before {
  color: #caa846;
}
/*****************************************************************
 GENERAL SETTING
*****************************************************************/
html {
  font-size: 12px;
  background-size: auto 75%, 100% auto;
  background-repeat: no-repeat, repeat-y;
  background-position: center bottom;
}
@media screen and (min-width: 800px) {
  html {
    font-size: 16px;
  }
}
body {
  font-family: "Noto Sans JP", sans-serif;
  background-color: #132925;
  background-image: url(../img/magic_circle.png), url(../img/magic_circle.png);
  background-size: auto 75vh, auto 75vh;
  background-repeat: no-repeat;
  background-attachment: fixed;
  background-position: right -37.5vh center, left -37.5vh center;
}
.container,
.inner,
.flash,
.flash-content {
  display: block;
  position: relative;
  margin: 0 auto;
}
.container,
.flash {
  overflow: hidden;
}
@media screen and (min-width: 1280px) {
  .container,
  .flash {
    max-width: 1280px;
  }
}
.container-title {
  color: #ffffff;
  text-align: center;
  text-shadow: -1px -1px 8px rgba(84, 46, 0, 0.8), -1px 0 8px rgba(84, 46, 0, 0.8), -1px 1px 8px rgba(84, 46, 0, 0.8), 0 -1px 8px rgba(84, 46, 0, 0.8), 0 1px 8px rgba(84, 46, 0, 0.8), 1px -1px 8px rgba(84, 46, 0, 0.8), 1px 0 8px rgba(84, 46, 0, 0.8), 1px 1px 8px rgba(84, 46, 0, 0.8);
  padding: 0.75rem 0;
  background-image: linear-gradient(to right, rgba(51, 51, 51, 0) 0%, rgba(51, 51, 51, 0.95) 50%, rgba(51, 51, 51, 0) 100%);
}
.inner,
.flash-content {
  padding: 1rem 1.5rem;
  z-index: 10;
}
@media screen and (min-width: 800px) {
  .inner,
  .flash-content {
    padding: 1rem 2.5rem;
  }
}
.controller {
  position: relative;
  margin: 1rem 0;
  text-align: center;
  overflow: hidden;
  z-index: 10;
}
@media screen and (min-width: 800px) {
  .controller-left,
  .controller-right {
    width: 50%;
  }
  .controller-left {
    text-align: left;
    float: left;
  }
  .controller-right {
    text-align: right;
    float: right;
  }
}
@media screen and (max-width: 799px) {
  .controller-left,
  .controller-right {
    text-align: right;
  }
  .controller-left {
    margin-bottom: 0.25rem;
  }
}
.controller > * {
  vertical-align: middle;
  display: inline-block;
}
ul.controller > li {
  list-style: none;
}
.controller:last-child {
  margin-bottom: 0;
}
.selection {
  position: relative;
  z-index: 10;
}
.selection .btn {
  min-width: auto;
}
a {
  text-decoration: underline;
  color: #344a6e;
}
a:hover,
a:focus {
  text-decoration: none;
  outline: none;
}
p {
  margin: 0.25em 0;
  line-height: 1.8em;
}
hr {
  position: relative;
  height: 1px;
  width: 90%;
  margin: 1.5rem auto;
  background-image: linear-gradient(to right, rgba(144, 148, 117, 0) 0%, #909475 20%, #909475 80%, rgba(144, 148, 117, 0) 100%);
  background-repeat: no-repeat;
  background-position: center;
  border: none;
}
@media screen and (min-width: 800px) {
  hr {
    width: 80%;
  }
}
hr::before,
hr::after {
  content: "";
  display: block;
  position: absolute;
  height: 100%;
  width: 100%;
  background-repeat: no-repeat;
  background-size: auto 100%;
  background-position: right center;
  z-index: -1;
}
hr::before {
  background-image: linear-gradient(to right, rgba(170, 170, 170, 0) 0%, #aaaaaa 20%, #aaaaaa 80%, rgba(170, 170, 170, 0) 100%);
  top: -1px;
}
hr::after {
  background-image: linear-gradient(to right, rgba(84, 46, 0, 0) 0%, #542e00 20%, #542e00 80%, rgba(84, 46, 0, 0) 100%);
  bottom: -1px;
}
.txt-center {
  text-align: center;
}
.txt-right {
  text-align: right;
}
.txt-left {
  text-align: left;
}
/*****************************************************************
 BUTTON
*****************************************************************/
.btn,
.level-gauge {
  overflow: visible;
  display: inline-block;
  position: relative;
  border-radius: 0.4rem;
  padding: 0.25rem 0.75rem;
  margin: 0.5rem;
  outline: none;
  cursor: pointer;
  text-align: center;
  font-weight: 500;
  color: #ffffff;
  text-decoration: none;
  text-shadow: -1px -1px 4px rgba(84, 46, 0, 0.6), -1px 0 4px rgba(84, 46, 0, 0.6), -1px 1px 4px rgba(84, 46, 0, 0.6), 0 -1px 4px rgba(84, 46, 0, 0.6), 0 1px 4px rgba(84, 46, 0, 0.6), 1px -1px 4px rgba(84, 46, 0, 0.6), 1px 0 4px rgba(84, 46, 0, 0.6), 1px 1px 4px rgba(84, 46, 0, 0.6);
  background-color: #909475;
  box-shadow: 0 0 6px 2px rgba(84, 46, 0, 0.25) inset;
  transition: background-color 0.5s ease;
}
.btn:hover,
.btn:active,
.btn.active,
input:checked + .btn {
  background-color: #346e65;
}
.btn::before,
.level-gauge::before {
  content: "";
  display: block;
  position: absolute;
  width: calc(100% + 0.25rem);
  height: calc(100% + 0.25rem);
  top: -0.125rem;
  left: -0.125rem;
  border-radius: 0.5rem;
  padding: 0.125rem;
  box-shadow: 0 0 2px 2px #542e00;
  background-image: linear-gradient(to bottom, #6f6229 0%, #caa846 20%, #d3c28f 35%, #ffffcb 50%, #d3c28f 75%, #caa846 80%, #6f6229 100%);
  z-index: -1;
}
.btn.primary {
  background-image: linear-gradient(to bottom,  rgba(52, 110, 101, 0)  0%, rgba(52, 110, 101, 0)  10%, #346e65  100% );
}
.btn.primary:hover,
.btn.primary:active,
.btn.primary.active,
input.primary:checked + .btn {
  background-color: #346e65;
  pointer-events: auto;
  color: #ffffff;
}
.btn.secondary {
  background-image: linear-gradient(to bottom,  rgba(52, 74, 110, 0)  0%, rgba(52, 74, 110, 0)  10%, #344a6e  100% );
}
.btn.secondary:hover,
.btn.secondary:active,
.btn.secondary.active,
input.secondary:checked + .btn {
  background-color: #344a6e;
  pointer-events: auto;
  color: #ffffff;
}
.btn.tertiary {
  background-image: linear-gradient(to bottom,  rgba(144, 52, 52, 0)  0%, rgba(144, 52, 52, 0)  10%, #903434  100% );
}
.btn.tertiary:hover,
.btn.tertiary:active,
.btn.tertiary.active,
input.tertiary:checked + .btn {
  background-color: #903434;
  pointer-events: auto;
  color: #ffffff;
}
.btn.quaternary {
  background-image: linear-gradient(to bottom,  rgba(78, 72, 62, 0)  0%, rgba(78, 72, 62, 0)  10%, #4e483e  100% );
}
.btn.quaternary:hover,
.btn.quaternary:active,
.btn.quaternary.active,
input.quaternary:checked + .btn {
  background-color: #4e483e;
  pointer-events: auto;
  color: #ffffff;
}
.btn.quinary {
  background-image: linear-gradient(to bottom,  rgba(144, 148, 117, 0)  0%, rgba(144, 148, 117, 0)  10%, #909475  100% );
}
.btn.quinary:hover,
.btn.quinary:active,
.btn.quinary.active,
input.quinary:checked + .btn {
  background-color: #909475;
  pointer-events: auto;
  color: #ffffff;
}
.btn.senary {
  background-image: linear-gradient(to bottom,  rgba(84, 46, 0, 0)  0%, rgba(84, 46, 0, 0)  10%, #542e00  100% );
}
.btn.senary:hover,
.btn.senary:active,
.btn.senary.active,
input.senary:checked + .btn {
  background-color: #542e00;
  pointer-events: auto;
  color: #ffffff;
}
.btn.septenary {
  background-image: linear-gradient(to bottom,  rgba(170, 170, 170, 0)  0%, rgba(170, 170, 170, 0)  10%, #aaaaaa  100% );
}
.btn.septenary:hover,
.btn.septenary:active,
.btn.septenary.active,
input.septenary:checked + .btn {
  background-color: #aaaaaa;
  pointer-events: auto;
  color: #ffffff;
}
.btn.octonary {
  background-image: linear-gradient(to bottom,  rgba(27, 174, 162, 0)  0%, rgba(27, 174, 162, 0)  10%, #1baea2  100% );
}
.btn.octonary:hover,
.btn.octonary:active,
.btn.octonary.active,
input.octonary:checked + .btn {
  background-color: #1baea2;
  pointer-events: auto;
  color: #ffffff;
}
.btn.nonary {
  background-image: linear-gradient(to bottom,  rgba(51, 51, 51, 0)  0%, rgba(51, 51, 51, 0)  10%, #333333  100% );
}
.btn.nonary:hover,
.btn.nonary:active,
.btn.nonary.active,
input.nonary:checked + .btn {
  background-color: #333333;
  pointer-events: auto;
  color: #ffffff;
}
.btn.denary {
  background-image: linear-gradient(to bottom,  rgba(255, 255, 255, 0)  0%, rgba(255, 255, 255, 0)  10%, #ffffff  100% );
}
.btn.denary:hover,
.btn.denary:active,
.btn.denary.active,
input.denary:checked + .btn {
  background-color: #ffffff;
  pointer-events: auto;
  color: #ffffff;
}
.btn.disable,
.btn:disabled,
input:disabled .btn {
  background: #595959;
  color: #aaaaaa;
  pointer-events: none;
}
.btn.disable::before,
.btn:disabled::before,
input:disabled .btn::before {
  background-image: linear-gradient(to bottom, #6f6f6f 0%, #cacaca 20%, #d3d3d3 35%, #ffffff 50%, #d3d3d3 75%, #cacaca 80%, #6f6f6f 100%);
}
.controller .btn {
  min-width: 10rem;
}
@media screen and (max-width: 799px) {
  .controller .btn {
    min-width: 8rem;
  }
}
@media screen and (min-width: 800px) {
  .btn.ss {
    min-width: auto;
  }
}
.orb {
  display: inline-block;
  position: relative;
  overflow: visible;
  width: 9.5rem;
  height: 9.5rem;
  border-radius: 50%;
  text-align: center;
  background-color: #ffffff;
  background-image: url(../img/orb_base.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100% 100%;
  z-index: 5;
}
a.orb,
label.orb {
  cursor: pointer;
  text-decoration: none;
}
.orb::before,
.orb::after {
  content: "";
  display: block;
  position: absolute;
}
.orb::before {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  border-radius: 50%;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  background-position: center;
  background-image: radial-gradient(circle, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0.25) 55%, rgba(255, 255, 255, 0) 100%);
  opacity: 0;
  transition: opacity 0.5s ease;
  z-index: 1;
}
.orb:hover::before,
.orb:active::before,
.orb.active::before,
input:checked + .orb::before {
  opacity: 1;
}
.orb.leaf::after {
  content: "";
  display: block;
  position: absolute;
  width: 86%;
  height: 86%;
  bottom: -4.5%;
  right: -15%;
  background-image: url(../img/orb_leaf.png);
  background-position: right bottom;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  z-index: 10;
}
.orb.character::before {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  border-radius: 50%;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  background-position: center;
  background-image: url(../img/orb_ring.png);
  opacity: 1;
  z-index: 15;
}
.orb.character img {
  display: block;
  width: 98.5%;
  border-radius: 50%;
  overflow: hidden;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  opacity: 1;
  transition: opacity 0.5s ease;
  z-index: 1;
}
.orb.character:hover img,
.orb.character:active img,
.orb.character.active img,
input:checked + .orb.character img {
  opacity: 0.7;
}
.orb span,
.orb i {
  position: relative;
  display: block;
  color: #ffffff;
  text-shadow: -1px -1px 4px rgba(84, 46, 0, 0.6), -1px 0 4px rgba(84, 46, 0, 0.6), -1px 1px 4px rgba(84, 46, 0, 0.6), 0 -1px 4px rgba(84, 46, 0, 0.6), 0 1px 4px rgba(84, 46, 0, 0.6), 1px -1px 4px rgba(84, 46, 0, 0.6), 1px 0 4px rgba(84, 46, 0, 0.6), 1px 1px 4px rgba(84, 46, 0, 0.6);
  font-weight: bold;
  font-weight: 700;
  z-index: 25;
}
.orb span {
  margin-top: 35%;
  font-size: 1.5rem;
  line-height: 1.6em;
}
.orb i {
  position: absolute;
  top: 22.5%;
  left: 0;
  right: 0;
  margin: 0 auto;
  font-size: 1.5rem;
}
.orb .badge {
  position: absolute;
  right: -0.25rem;
  bottom: -0.25rem;
}
.orb .badge i {
  display: inline-block;
  font-size: 0.925rem;
  position: relative;
  top: auto;
  vertical-align: top;
  height: 2.25rem;
  line-height: 2.25rem;
}
/*****************************************************************
 BADGE
*****************************************************************/
.badge {
  display: inline-block;
  height: 2.25rem;
  width: 2.25rem;
  line-height: 2.25rem;
  position: relative;
  z-index: 1;
  text-align: center;
  color: #ffffff;
  font-size: 0.8125rem;
  font-weight: 500;
}
.badge::before,
.badge::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  border-radius: 50%;
}
.badge::before {
  height: 2rem;
  width: 2rem;
  box-shadow: 0 0 2px 2px #542e00;
  background-size: 150%;
  background-position: center;
  background-image: linear-gradient(to bottom, #6f6229 0%, #caa846 20%, #d3c28f 35%, #ffffcb 50%, #d3c28f 75%, #caa846 80%, #6f6229 100%);
  z-index: -1;
}
.badge::after {
  height: calc(1.75rem);
  width: calc(1.75rem);
  background-color: #c10303;
  box-shadow: 0 0 6px 2px rgba(84, 46, 0, 0.8) inset;
  z-index: -1;
}
/*****************************************************************
 PANEL
*****************************************************************/
.panel,
.frame {
  display: block;
  width: 100%;
  position: relative;
  color: #ffffff;
  text-decoration: none;
  border-radius: 0.4rem;
  background-color: #4e483e;
  background-image: linear-gradient(to bottom, rgba(51, 51, 51, 0.75) 0%, rgba(51, 51, 51, 0) 100%);
  transition: background-color 0.5s ease;
  padding: 0.75rem;
  margin: 2rem 0;
}
.panel img,
.frame img {
  max-width: 100%;
}
a.panel::after,
a.frame::after {
  content: "\0203A";
  display: block;
  color: #ffffff;
  width: 2.5rem;
  height: 2.5rem;
  line-height: 2.5rem;
  font-size: 2.5rem;
  text-align: right;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto 0;
  right: 0.25em;
  z-index: 20;
}
a.panel:hover,
a.panel:active,
a.frame:hover,
a.frame:active {
  background-color: #aaaaaa;
}
@media screen and (min-width: 1280px) {
  .panel,
  .frame {
    padding: 1.25rem 1.5rem;
  }
}
.panel::before,
.frame::before {
  content: "";
  display: block;
  position: absolute;
  width: calc(100% + 0.25rem);
  height: calc(100% + 0.25rem);
  top: -0.125rem;
  left: -0.125rem;
  border-radius: 0.5rem;
  padding: 0.125rem;
  box-shadow: 0 0 2px 2px #542e00;
  background: linear-gradient(to bottom, #6f6229 0%, #caa846 20%, #d3c28f 35%, #ffffcb 50%, #d3c28f 75%, #caa846 80%, #6f6229 100%);
  background-repeat: repeat-y;
  background-size: 100% 50%;
  z-index: -1;
}
.panel.primary,
.frame.primary {
  background-color: #346e65;
}
.panel.secondary,
.frame.secondary {
  background-color: #344a6e;
}
.panel.tertiary,
.frame.tertiary {
  background-color: #903434;
}
.panel.quaternary,
.frame.quaternary {
  background-color: #4e483e;
}
.panel.quinary,
.frame.quinary {
  background-color: #909475;
}
.panel.senary,
.frame.senary {
  background-color: #542e00;
}
.panel.septenary,
.frame.septenary {
  background-color: #aaaaaa;
}
.panel.octonary,
.frame.octonary {
  background-color: #1baea2;
}
.panel.nonary,
.frame.nonary {
  background-color: #333333;
}
.panel.denary,
.frame.denary {
  background-color: #ffffff;
}
.panel-title,
.frame-title {
  font-size: 1.25rem;
  font-weight: 500;
}
.panel-content,
.frame-content {
  margin: 0 auto;
}
.panel-content:last-child,
.frame-content:last-child {
  margin-bottom: 0;
}
@media screen and (max-width: 799px) {
  .panel-content,
  .frame-content {
    font-size: 1.1em;
  }
}
.panel > span:not(.orb),
.panel > time,
.panel-title,
.panel-title > *,
.frame > span:not(.orb),
.frame > time,
.frame-title,
.frame-title > * {
  display: inline-block;
  margin: 0 0.5rem;
}
.panel time,
.panel .tag-list,
.frame time,
.frame .tag-list {
  font-size: 0.925rem;
}
@media screen and (max-width: 1279px) {
  .panel time,
  .panel .tag-list,
  .frame time,
  .frame .tag-list {
    font-size: 0.8125rem;
    display: block;
  }
}
.panel .balloon,
.frame .balloon {
  width: 100%;
}
.panel-list .panel,
.frame-list .frame {
  margin-bottom: 2.25rem;
}
.panel-list li,
.frame-list li {
  list-style: none;
  position: relative;
}
.panel-closer,
.frame-closer {
  position: absolute;
  top: 0.25rem;
  right: 0.25rem;
  z-index: 100;
}

.frame .panel-closer{
  top: 1.25rem;
  right: 1.25rem;
  position: absolute;
  width: 35px;
  height: 32px;
}
.frame .panel-closer .btn.tertiary{
  width: 100%;
  min-width: 0;
  height: 100%;
  margin: 0;
}
@media screen and (max-width: 799px) {
.panel-closer,
.frame-closer {
transform: scale(1.15);
}
  .frame .panel-closer{
    width: auto;
    height: auto;
  }
}
.panel-closer .btn i,
.frame-closer .btn i {
font-weight: 700;
display: inline-block;
min-width: 0.5rem;
font-style: normal;
}
/*****************************************************************
FRAME
*****************************************************************/
.frame-title {
  display: block;
  font-family: 'Tangerine', cursive;
  font-weight: 700;
  font-size: 2rem;
  text-align: center;
}
.frame-title span {
  display: inline-block;
  padding: 0.125rem 0.5rem;
  vertical-align: middle;
  text-shadow: -1px -1px 4px rgba(84, 46, 0, 0.6), -1px 0 4px rgba(84, 46, 0, 0.6), -1px 1px 4px rgba(84, 46, 0, 0.6), 0 -1px 4px rgba(84, 46, 0, 0.6), 0 1px 4px rgba(84, 46, 0, 0.6), 1px -1px 4px rgba(84, 46, 0, 0.6), 1px 0 4px rgba(84, 46, 0, 0.6), 1px 1px 4px rgba(84, 46, 0, 0.6);
}
.frame-title::before,
.frame-title::after {
  content: "";
  display: inline-block;
  width: 1rem;
  height: 1rem;
  background-image: url(../img/gem_green.png);
  background-size: contain;
  vertical-align: middle;
}
.frame-content {
  width: 90%;
  margin: 2rem auto;
  z-index: 10;
}
@media screen and (min-width: 1280px) {
  .frame-content {
    width: 80%;
  }
}
@media screen and (max-width: 799px) {
  .frame-content p {
    font-size: 1.1em;
  }
}
.frame::after {
  content: "";
  display: block;
  position: absolute;
  left: -1rem;
  top: -1rem;
  width: calc(100% + 2rem);
  height: calc(100% + 2rem);
  background-repeat: no-repeat;
  background-image: url(../img/gr_lb.png), url(../img/gr_lt.png), url(../img/gr_rb.png), url(../img/gr_rt.png);
  background-size: 8rem;
  background-position: left bottom, left top, right bottom, right top;
  z-index: 1;
}
.frame > * {
  position: relative;
}
/*****************************************************************
 CARD
*****************************************************************/
.card {
  display: inline-block;
  position: relative;
  cursor: pointer;
  transition: all ease 0.5s;
  padding: 1rem;
}
.card i,
.card span {
  text-shadow: -1px -1px 4px rgba(84, 46, 0, 0.6), -1px 0 4px rgba(84, 46, 0, 0.6), -1px 1px 4px rgba(84, 46, 0, 0.6), 0 -1px 4px rgba(84, 46, 0, 0.6), 0 1px 4px rgba(84, 46, 0, 0.6), 1px -1px 4px rgba(84, 46, 0, 0.6), 1px 0 4px rgba(84, 46, 0, 0.6), 1px 1px 4px rgba(84, 46, 0, 0.6);
  color: #ffffff;
}
.card i {
  font-size: 5rem;
  transition: color ease 0.5s;
}
.card:hover,
.card:focus,
.card:active {
  transform: scale(-1, 1);
}
.card:hover i.ra-clovers-card,
.card:focus i.ra-clovers-card,
.card:active i.ra-clovers-card {
  color: #346e65;
}
.card:hover i.ra-diamonds-card,
.card:focus i.ra-diamonds-card,
.card:active i.ra-diamonds-card {
  color: #909475;
}
.card:hover i.ra-spades-card,
.card:focus i.ra-spades-card,
.card:active i.ra-spades-card {
  color: #344a6e;
}
.card:hover i.ra-hearts-card,
.card:focus i.ra-hearts-card,
.card:active i.ra-hearts-card {
  color: #903434;
}
.card-list {
  display: block;
  text-align: center;
}
/*****************************************************************
 PLATE
*****************************************************************/
/*****************************************************************
 LEVEL
*****************************************************************/
.level {
  position: relative;
  z-index: 100;
}
@media screen and (max-width: 799px) {
  .level {
    height: 1.15rem;
    width: 80%;
  }
}
@media screen and (min-width: 800px) {
  .level {
    height: 1.35rem;
    width: 16.5rem;
  }
}
.level-gauge {
  margin: 0;
  width: 100%;
  position: absolute;
  left: -0.125rem;
  top: -0.125rem;
  background-color: #333333;
  height: 100%;
  border-radius: 0.9rem;
  cursor: auto;
}
.level-gauge::before {
  border-radius: 1.25rem;
}
.level-gauge span {
  display: block;
  height: 100%;
  min-width: 1rem;
  border-radius: 1rem;
  position: absolute;
  top: 0;
  left: 0;
  background-image: linear-gradient(to bottom, #3c7f75, #58b0a2 50%, #4da295 51%, #afd9d2 100%);
  box-shadow: 0 0 6px 2px rgba(84, 46, 0, 0.8) inset;
}
.level-number {
  position: absolute;
  line-height: 1em;
  bottom: 0.925rem;
  right: 1rem;
  text-shadow: -1px -1px 4px rgba(84, 46, 0, 0.6), -1px 0 4px rgba(84, 46, 0, 0.6), -1px 1px 4px rgba(84, 46, 0, 0.6), 0 -1px 4px rgba(84, 46, 0, 0.6), 0 1px 4px rgba(84, 46, 0, 0.6), 1px -1px 4px rgba(84, 46, 0, 0.6), 1px 0 4px rgba(84, 46, 0, 0.6), 1px 1px 4px rgba(84, 46, 0, 0.6);
}
@media screen and (min-width: 800px) {
  .level-number {
    font-size: 1.5rem;
  }
}
@media screen and (max-width: 799px) {
  .level-number {
    font-size: 1.15rem;
  }
}
/*****************************************************************
 TAG
*****************************************************************/
li.tag {
  list-style: none;
  display: inline-block;
  padding: 0.25rem 0.75rem;
  margin: 0 0.25rem 0.25rem;
  font-size: 0.925rem;
  color: #ffffff;
  border-radius: 0.5rem;
  background-color: #909475;
  box-shadow: 0 0 2px 2px #542e00;
  text-shadow: -1px -1px 4px rgba(84, 46, 0, 0.6), -1px 0 4px rgba(84, 46, 0, 0.6), -1px 1px 4px rgba(84, 46, 0, 0.6), 0 -1px 4px rgba(84, 46, 0, 0.6), 0 1px 4px rgba(84, 46, 0, 0.6), 1px -1px 4px rgba(84, 46, 0, 0.6), 1px 0 4px rgba(84, 46, 0, 0.6), 1px 1px 4px rgba(84, 46, 0, 0.6);
}
li.tag.primary {
  background-color: #346e65;
}
li.tag.secondary {
  background-color: #344a6e;
}
li.tag.tertiary {
  background-color: #903434;
}
li.tag.quaternary {
  background-color: #4e483e;
}
li.tag.quinary {
  background-color: #909475;
}
li.tag.senary {
  background-color: #542e00;
}
li.tag.septenary {
  background-color: #aaaaaa;
}
li.tag.octonary {
  background-color: #1baea2;
}
li.tag.nonary {
  background-color: #333333;
}
li.tag.denary {
  background-color: #ffffff;
}
/*****************************************************************
 BALLOON
*****************************************************************/
.balloon {
  position: relative;
  padding: 0.5rem 1rem;
  margin: 1rem 0;
  border-radius: 0.5rem;
  color: #333333;
  background-color: #aaaaaa;
  text-align: left;
}
.balloon::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  position: absolute;
  top: 0.5rem;
  left: -0.725rem;
  border-style: solid;
  border-width: 0 0.75rem 0.75rem 0;
  border-color: transparent #aaaaaa transparent transparent;
}
.to .balloon {
  background-color: #8eede6;
}
.to .balloon::before {
  border-right-color: #8eede6;
  right: -0.725rem;
  left: auto;
  transform: scale(-1, 1);
}
.from .balloon {
  background-color: #ffffff;
}
.from .balloon::before {
  border-right-color: #ffffff;
}
.balloon-closer {
  display: inline-block;
  position: absolute;
  top: 0.25rem;
  right: 0.25rem;
  padding: 0.25rem;
  cursor: pointer;
}
.balloon-closer i {
  font-size: 1.75rem;
}
.balloon-closer + p {
  padding-right: 1.5rem;
}
/*****************************************************************
 PAGINATION
*****************************************************************/
ol.pagination {
  text-align: center;
  margin: 2rem auto;
}
ol.pagination li {
  list-style: none;
  display: inline-block;
  margin: 0 0.025rem;
}
@media screen and (max-width: 799px) {
  ol.pagination li:not(.prever):not(.prev):not(.current):not(.next):not(.nexter) {
    display: none;
  }
}
ol.pagination .btn i {
  display: inline-block;
  min-width: 0.5rem;
  font-style: normal;
  transform: scale(1.5) translateY(-7.5%);
}
/*****************************************************************
 TABLE
*****************************************************************/
table.calendar {
  margin: 1rem auto;
  overflow: hidden;
  text-align: center;
}
table.calendar td,
table.calendar th {
  position: relative;
  border: solid 1px #ffffff;
  border-radius: 0.5rem;
  width: 3.5rem;
  height: 3.5rem;
  line-height: 3.5rem;
}
table.calendar td label,
table.calendar th label {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 99;
  cursor: pointer;
  font-size: 1.25rem;
}
table.calendar td label:hover,
table.calendar th label:hover,
table.calendar td label:active,
table.calendar th label:active {
  background-color: rgba(170, 170, 170, 0.1);
}
table.calendar td > div.beer::before,
table.calendar th > div.beer::before {
  content: "\f0fc";
}
table.calendar td > div.hamburger::before,
table.calendar th > div.hamburger::before {
  content: "\f805";
}
table.calendar td > div.coffee::before,
table.calendar th > div.coffee::before {
  content: "\f0f4";
}
table.calendar td > div::before,
table.calendar th > div::before {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  font-size: 2.5rem;
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  opacity: 0.65;
  color: #caccbd;
  z-index: 0;
}
/*****************************************************************
 MODAL
*****************************************************************/
.modal,
.loot {
  text-align: center;
  overflow: visible;
  position: fixed;
  width: 100vw;
  height: 100vh;
  z-index: -1;
  left: 0;
  transition: opacity 0.5s ease;
}
input:not(:checked) + .modal,
input:not(:checked) + .loot {
  top: -200vh;
  opacity: 0;
}
input:checked + .modal,
input:checked + .loot {
  top: 0;
  opacity: 1;
  z-index: 900;
}
.modal-over,
.loot-over {
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  background-color: rgba(51, 51, 51, 0.7);
  z-index: -1;
}
.modal-container,
.loot-container {
  position: relative;
  display: block;
  top: 50%;
  transform: translateY(-50%);
  margin: 0 auto;
  z-index: 10;
}
@media screen and (max-width: 799px) {
  .modal-container,
  .loot-container {
    width: 100%;
  }
}
.modal .panel,
.modal .frame,
.modal .frame,
.loot .panel,
.loot .frame {
  margin: 0 auto;
  left: 0;
  right: 0;
  padding-top: 3.25rem;
}
@media screen and (min-width: 800px) {
  .modal .panel,
  .modal .frame,
  .modal .frame,
  .loot .panel,
  .loot .frame {
    width: 600px;
  }
}
@media screen and (max-width: 799px) {
  .modal .panel,
  .modal .frame,
  .modal .frame,
  .loot .panel,
  .loot .frame {
    width: 90%;
  }
}
.loot-over {
  width: 0;
  height: 0;
  opacity: 1;
  border-radius: 50%;
  background-image: radial-gradient(circle, #ffffff, rgba(255, 255, 255, 0.55) 55%, rgba(255, 255, 255, 0.25) 100%);
  transition: height 1s linear 1.25s, width 1s linear 1.25s, opacity 1.75s linear 0.25s;
  left: -100%;
  right: -100%;
}
.loot-container {
  opacity: 0;
  transition: opacity 1.5s ease-out 2.5s;
}
input:checked + .loot {
  z-index: 2000;
}
input:checked + .loot .loot-over {
  opacity: 0.7;
  width: 175vw;
  height: 175vw;
}
@media screen and (max-width: 799px) {
  input:checked + .loot .loot-over {
    width: 175vh;
    height: 175vh;
  }
}
input:checked + .loot .loot-container {
  opacity: 1;
}
/*****************************************************************
 FLASH MESSAGE
*****************************************************************/
.flash {
  position: fixed;
  left: 0;
  right: 0;
  margin: 0 auto;
  z-index: 600;
  -webkit-animation: flash 1s ease 2s forwards;
  -moz-animation: flash 1s ease 2s forwards;
  animation: flash 1s ease 2s forwards;
}
@-webkit-keyframes flash {
  0% {
    opacity: 1;
  }
  99% {
    opacity: 0;
  }
  100% {
    opacity: 0;
    display: none;
    z-index: -1;
  }
}
@-moz-keyframes flash {
  0% {
    opacity: 1;
  }
  99% {
    opacity: 0;
  }
  100% {
    opacity: 0;
    display: none;
    z-index: -1;
  }
}
@keyframes flash {
  0% {
    opacity: 1;
  }
  99% {
    opacity: 0;
  }
  100% {
    opacity: 0;
    display: none;
    z-index: -1;
  }
}
.flash-content .panel,
.flash-content .frame {
  margin-top: 0;
}
main .container {
  overflow: hidden;
  min-height: 100vh;
  background-image: linear-gradient(to bottom right, rgba(52, 110, 101, 0.85) 0%, rgba(52, 110, 101, 0) 45%, rgba(170, 170, 170, 0) 65%, rgba(170, 170, 170, 0.85) 100%), url(../img/background.jpg);
  background-size: cover;
  background-repeat: no-repeat;
  background-attachment: fixed;
  background-position: center;
  z-index: 10;
}
@media screen and (min-width: 1280px) {
  main .container {
    padding-top: 110px;
    padding-bottom: 6.5rem;
  }
}
@media screen and (min-width: 800px) and (max-width: 1279px) {
  main .container {
    padding-top: 95px;
    padding-bottom: 6.5rem;
  }
}
@media screen and (max-width: 799px) {
  main .container {
    padding-top: 85px;
    padding-bottom: 127.5px;
  }
}
@media screen and (min-width: 800px) {
  .ban-pc {
    display: none;
  }
}
@media screen and (max-width: 799px) {
  .ban-sp {
    display: none;
  }
}
/*****************************************************************
 HEADER
*****************************************************************/
header {
  display: block;
  position: fixed;
  width: 100%;
  z-index: 800;
}
@media screen and (max-width: 799px) {
  header .container {
    height: 85px;
    line-height: 85px;
  }
  header .container::before {
    height: 30px;
  }
  header .menu,
  header .subject {
    height: 85px;
    padding: 4.25px;
  }
  header .menu::before,
  header .subject::before,
  header .menu::after,
  header .subject::after {
    width: 85px;
  }
  header .menu {
    background-position: center;
    margin-right: 0.5rem;
  }
  header .menu::before {
    height: 30px;
    left: -2.125px;
  }
  header .menu::after {
    top: 0;
    right: -9.775px;
    height: 85px;
  }
  header .subject {
    background-position: left center, right center, center;
    margin-left: 0.5rem;
  }
  header .subject::after {
    height: 30px;
    right: -2.125px;
  }
  header .subject::before {
    top: 0;
    left: -9.775px;
    height: 85px;
  }
  header .subject .orb {
    border-radius: 42.5px;
  }
  header .subject .orb::before {
    border-radius: 38.25px;
  }
  header .subject .orb::after {
    width: 73.1px;
    left: -12.75px;
  }
  header .orb {
    height: 76.5px;
    width: 76.5px;
  }
}
@media screen and (min-width: 800px) and (max-width: 1279px) {
  header .container {
    height: 95px;
    line-height: 95px;
  }
  header .container::before {
    height: 34px;
  }
  header .menu,
  header .subject {
    height: 95px;
    padding: 4.75px;
  }
  header .menu::before,
  header .subject::before,
  header .menu::after,
  header .subject::after {
    width: 95px;
  }
  header .menu {
    background-position: center;
    margin-right: 0.5rem;
  }
  header .menu::before {
    height: 34px;
    left: -2.375px;
  }
  header .menu::after {
    top: 0;
    right: -10.925px;
    height: 95px;
  }
  header .subject {
    background-position: left center, right center, center;
    margin-left: 0.5rem;
  }
  header .subject::after {
    height: 34px;
    right: -2.375px;
  }
  header .subject::before {
    top: 0;
    left: -10.925px;
    height: 95px;
  }
  header .subject .orb {
    border-radius: 47.5px;
  }
  header .subject .orb::before {
    border-radius: 42.75px;
  }
  header .subject .orb::after {
    width: 81.7px;
    left: -14.25px;
  }
  header .orb {
    height: 85.5px;
    width: 85.5px;
  }
}
@media screen and (min-width: 1280px) {
  header .container {
    height: 110px;
    line-height: 110px;
  }
  header .container::before {
    height: 39px;
  }
  header .menu,
  header .subject {
    height: 110px;
    padding: 5.5px;
  }
  header .menu::before,
  header .subject::before,
  header .menu::after,
  header .subject::after {
    width: 110px;
  }
  header .menu {
    background-position: center;
    margin-right: 0.5rem;
  }
  header .menu::before {
    height: 39px;
    left: -2.75px;
  }
  header .menu::after {
    top: 0;
    right: -12.65px;
    height: 110px;
  }
  header .subject {
    background-position: left center, right center, center;
    margin-left: 0.5rem;
  }
  header .subject::after {
    height: 39px;
    right: -2.75px;
  }
  header .subject::before {
    top: 0;
    left: -12.65px;
    height: 110px;
  }
  header .subject .orb {
    border-radius: 55px;
  }
  header .subject .orb::before {
    border-radius: 49.5px;
  }
  header .subject .orb::after {
    width: 94.6px;
    left: -16.5px;
  }
  header .orb {
    height: 99px;
    width: 99px;
  }
}
header .container::before {
  content: "";
  display: block;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-image: url(../img/menu_back_half.png);
  background-size: auto 100%;
  background-repeat: repeat-x;
  transform: scaleY(-1);
  z-index: -1;
}
header .menu {
  display: block;
  position: absolute;
  right: 0;
  top: 0;
  background-repeat: no-repeat;
  background-image: url(../img/menu_base.png);
  background-size: auto 100%;
}
header .menu::before,
header .menu::after {
  content: "";
  display: block;
  position: absolute;
  background-size: auto 100%;
  background-position: right center;
  z-index: -1;
}
header .menu::before {
  top: 0;
  transform: scale(-1, -1) skewX(-10deg);
  background-image: url(../img/menu_half_pat01.png);
}
header .menu::after {
  transform: scaleY(-1);
  background-image: url(../img/menu_side_pat01.png);
}
header .orb {
  vertical-align: top;
}
@media screen and (max-width: 799px) {
  header .orb span {
    font-size: 1.25rem;
  }
}
@media screen and (min-width: 800px) and (max-width: 1279px) {
  header .orb span {
    font-size: 1.15rem;
  }
  header .orb i {
    font-size: 1.25rem;
  }
}
@media screen and (min-width: 1280px) {
  header .orb span {
    font-size: 1.25rem;
  }
}
header .subject {
  min-width: 200px;
  font-family: 'Tangerine', cursive;
  text-align: center;
  background-image: url(../img/menu_base_head.png), url(../img/menu_base_end.png), url(../img/menu_base_back.png);
  background-repeat: no-repeat;
  background-size: auto 100%, auto 100%, 68.5% 100%;
  position: absolute;
  top: 0;
  left: 0;
  width: 35%;
  color: #ffffff;
  font-weight: 700;
  text-shadow: -1px -1px 8px rgba(84, 46, 0, 0.8), -1px 0 8px rgba(84, 46, 0, 0.8), -1px 1px 8px rgba(84, 46, 0, 0.8), 0 -1px 8px rgba(84, 46, 0, 0.8), 0 1px 8px rgba(84, 46, 0, 0.8), 1px -1px 8px rgba(84, 46, 0, 0.8), 1px 0 8px rgba(84, 46, 0, 0.8), 1px 1px 8px rgba(84, 46, 0, 0.8);
}
@media screen and (max-width: 360px -1) {
  header .subject {
    background-size: auto 100%, auto 100%, 62.5% 100%;
  }
}
header .subject .orb {
  width: 100%;
  background-color: #909475;
  background-image: url(../img/ring_head.png), url(../img/ring_end.png), url(../img/ring_back.png), url(../img/subject_base.png);
  background-repeat: no-repeat;
  background-size: auto 100%, auto 100%, 75% 100%, cover;
  background-position: left center, right center, center top, right center;
}
@media screen and (max-width: 360px -1) {
  header .subject .orb {
    background-size: auto 100%, auto 100%, 60% 100%, 100%;
  }
}
header .subject .orb::after {
  transform: scaleX(-1);
}
header .subject .orb::before {
  background: none;
  opacity: 1;
  z-index: -1;
}
@media screen and (min-width: 1280px) {
  header .subject {
    font-size: 2.8rem;
  }
}
@media screen and (max-width: 1279px) {
  header .subject {
    max-width: 360px;
    font-size: 2rem;
  }
}
@media screen and (max-width: 799px) {
  header .subject {
    width: calc(100% - (85px * 1.25));
  }
}
header .subject::before,
header .subject::after {
  content: "";
  display: block;
  position: absolute;
  background-size: auto 100%;
  background-position: right center;
  z-index: -1;
}
header .subject::after {
  top: 0;
  transform: scaleY(-1) skewX(-11deg);
  background-image: url(../img/menu_half_pat01.png);
}
header .subject::before {
  transform: scale(-1, -1);
  background-image: url(../img/menu_side_pat01.png);
}
input#Menu:checked ~ header .menu .orb::before {
  opacity: 1;
}
/*****************************************************************
 NAV MENU
*****************************************************************/
nav.sub-menu {
  z-index: 10;
}
nav.sub-menu ul {
  line-height: normal;
  font-size: 0;
  letter-spacing: 0;
}
@media screen and (max-width: 799px) {
  nav.sub-menu ul {
    margin: 0 -0.8125rem;
  }
}
nav.sub-menu ul li {
  list-style: none;
  position: relative;
  display: inline-block;
  vertical-align: middle;
}
nav.sub-menu .orb span {
  margin-top: 60%;
  font-weight: 500;
  font-size: 0.625rem;
}
@media screen and (max-width: 799px) {
}
@media screen and (min-width: 800px) {
  nav.sub-menu .orb span {
    font-size: 0.625rem;
  }
}
@media screen and (max-width: 799px) {
}
nav.sub-menu .badge {
  position: absolute;
  top: -0.125rem;
  right: -0.125rem;
  z-index: 100;
}
@media screen and (min-width: 800px) {
  nav.sub-menu {
    position: absolute;
    top: 0;
  }
}
@media screen and (max-width: 799px) {
  nav.sub-menu {
    width: 100%;
    position: fixed;
    left: 0;
    bottom: 0;
  }
}
@media screen and (max-width: 799px) {
  nav.sub-menu {
    right: 115px;
    height: 64px;
    background-image: url(../img/menu_back_half.png);
    background-position: bottom center;
    background-repeat: repeat-x;
    background-size: auto 30px;
    text-align: center;
  }
  nav.sub-menu li {
    padding: 4.25px 10.625px;
  }
  nav.sub-menu li::before,
  nav.sub-menu li::after {
    height: 30px;
  }
  nav.sub-menu .orb {
    height: 57.375px;
    width: 57.375px;
  }
}
@media screen and (min-width: 800px) and (max-width: 1279px) {
  nav.sub-menu {
    right: 129px;
    height: 72px;
  }
  nav.sub-menu li {
    padding: 4.75px 11.875px;
  }
  nav.sub-menu li::before,
  nav.sub-menu li::after {
    height: 34px;
  }
  nav.sub-menu .orb {
    height: 64.125px;
    width: 64.125px;
  }
}
@media screen and (min-width: 1280px) {
  nav.sub-menu {
    right: 149px;
    height: 83px;
  }
  nav.sub-menu li {
    padding: 5.5px 13.75px;
  }
  nav.sub-menu li::before,
  nav.sub-menu li::after {
    height: 39px;
  }
  nav.sub-menu .orb {
    height: 74.25px;
    width: 74.25px;
  }
}
nav.sub-menu li {
  vertical-align: bottom;
  background-repeat: no-repeat;
  background-image: url(../img/menu_base.png);
  background-size: auto 99%;
  background-position: center center;
}
nav.sub-menu li::before,
nav.sub-menu li::after {
  content: "";
  display: block;
  width: 70%;
  position: absolute;
  background-size: auto 100%;
  background-position: right bottom;
  background-image: url(../img/menu_half_pat02.png);
  z-index: -1;
}
nav.sub-menu li::before {
  left: 0;
  transform: scaleX(-1);
}
nav.sub-menu li::after {
  right: 0;
}
@media screen and (max-width: 799px) {
  nav.sub-menu li {
    top: -2.125px;
  }
  nav.sub-menu li::before,
  nav.sub-menu li::after {
    bottom: 0;
  }
}
@media screen and (min-width: 800px) {
  nav.sub-menu li::before,
  nav.sub-menu li::after {
    top: 0;
  }
  nav.sub-menu li::before {
    transform: scale(-1, -1);
  }
  nav.sub-menu li::after {
    transform: scaleY(-1);
  }
}
nav.side-menu {
  z-index: 800;
}
@media screen and (min-width: 800px) {
  nav.side-menu {
    position: fixed;
    margin-top: 2rem;
  }
}
@media screen and (min-width: 1280px) {
  nav.side-menu {
    right: calc(50% - 1280px / 2);
  }
}
@media screen and (min-width: 800px) and (max-width: 1279px) {
  nav.side-menu {
    right: 0;
  }
}
@media screen and (max-width: 799px) {
  nav.side-menu {
    top: 100px;
    position: absolute;
    right: 0;
  }
}
nav.side-menu ul {
  text-align: right;
  padding-right: 0.5rem;
  overflow: hidden;
}
nav.side-menu ul li {
  position: relative;
  display: inline-block;
  list-style: none;
  margin-bottom: 0.5rem;
  text-align: left;
  background-image: url(../img/menu_base.png);
  background-size: auto 99%;
  background-position: left center;
}
@media screen and (min-width: 800px) {
  nav.side-menu ul li {
    font-size: 1.75rem;
  }
}
nav.side-menu ul li::after {
  content: "";
  display: block;
  top: 0;
  left: 50%;
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: -1;
  transform: scaleY(-1);
  background-image: url(../img/menu_side_pat01.png), url(../img/menu_back.png);
  background-size: auto 100%;
  background-position: left center, left center;
}
nav.side-menu ul li i {
  font-size: 1.75rem;
}
@media screen and (min-width: 1280px) {
  nav.side-menu ul li i {
    font-size: 2.125rem;
  }
}
nav.side-menu ul li span {
  margin-top: 60%;
  font-size: 0.8125rem;
  line-height: 1.6em;
}
@media screen and (min-width: 1280px) {
  nav.side-menu ul li span {
    font-size: 1rem;
  }
}
@media screen and (min-width: 800px) {
  nav.side-menu ul li:first-child span {
    margin-top: 62.5%;
  }
}
@media screen and (min-width: 800px) and (max-width: 1279px) {
  nav.side-menu ul li:first-child span {
    font-size: 1.1rem;
  }
}
@media screen and (max-width: 799px) {
  nav.side-menu li {
    height: 93.5px;
    width: 93.5px;
    padding: 4.25px;
  }
  nav.side-menu .orb {
    height: 85px;
    width: 85px;
  }
  nav.side-menu ul {
    width: 72.25px;
  }
  nav.side-menu ul li {
    height: 68px;
    padding: 3.4px;
  }
  nav.side-menu ul li::after {
    left: 37.5%;
  }
  nav.side-menu ul .orb {
    height: 61.2px;
    width: 61.2px;
  }
}
@media screen and (min-width: 800px) and (max-width: 1279px) {
  nav.side-menu li {
    height: 104.5px;
    width: 104.5px;
    padding: 4.75px;
  }
  nav.side-menu .orb {
    height: 95px;
    width: 95px;
  }
  nav.side-menu ul {
    width: 151.2875px;
  }
  nav.side-menu li {
    text-align: center;
  }
  nav.side-menu li:first-child {
    height: 130.625px;
    width: 130.625px;
  }
  nav.side-menu li:first-child .orb {
    height: 118.75px;
    width: 118.75px;
  }
  nav.side-menu li:first-child .orb i {
    font-size: 2.5rem;
  }
}
@media screen and (min-width: 1280px) {
  nav.side-menu li {
    height: 121px;
    width: 121px;
    padding: 5.5px;
  }
  nav.side-menu .orb {
    height: 110px;
    width: 110px;
  }
  nav.side-menu ul {
    width: 175.175px;
  }
  nav.side-menu li:first-child {
    height: 151.25px;
    width: 151.25px;
  }
  nav.side-menu li:first-child .orb {
    height: 137.5px;
    width: 137.5px;
  }
  nav.side-menu li:first-child .orb i {
    font-size: 2.8125rem;
  }
}
@media screen and (min-width: 800px) {
  nav.main-menu .frame {
    min-height: 600px;
  }
}
@media screen and (max-width: 799px) {
}
nav.main-menu .frame .btn {
  height: 5rem;
  width: 5.75rem;
  min-width: 5.75rem;
}
nav.main-menu .frame .btn i:not(.closer),
nav.main-menu .frame .btn span {
  position: absolute;
  display: block;
  left: 0;
  right: 0;
  margin: 0 auto;
}
nav.main-menu .frame .btn i:not(.closer) {
  top: 0.75rem;
  font-size: 1.5rem;
}
nav.main-menu .frame .btn span {
  margin-top: 60%;
  font-size: 0.75rem;
  transform: translateY(-50%);
}
/*****************************************************************
 BRANDING
*****************************************************************/
.branding {
  width: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  padding: 2.5rem 0 1rem 0;
  background-image: linear-gradient(to bottom, rgba(51, 51, 51, 0) 0%, rgba(51, 51, 51, 0.9) 25%);
  z-index: 100;
}
.branding img {
  height: 2.25rem;
  display: block;
  margin: 0 auto;
}
@media screen and (max-width: 799px) {
  .branding {
    padding: 3.5rem 0 6.5rem 0;
  }
}
/*****************************************************************
 SECTIONING
*****************************************************************/
@media screen and (max-width: 799px) {
  #Guild .panel,
  #Message.list .panel,
  #Board.list .panel,
  #Board.detail .panel,
  #Favorite.list .panel,
  #FootPrint.list .panel,
  #Companies.list .panel,
  #Calendar.list .panel,
  #Message.search .panel,
  #Board.search .panel,
  #Favorite.search .panel,
  #FootPrint.search .panel,
  #Companies.search .panel,
  #Calendar.search .panel,
  #Message.list .frame,
  #Board.list .frame,
  #Favorite.list .frame,
  #FootPrint.list .frame,
  #Companies.list .frame,
  #Calendar.list .frame,
  #Message.search .frame,
  #Board.search .frame,
  #Favorite.search .frame,
  #FootPrint.search .frame,
  #Companies.search .frame,
  #Calendar.search .frame {
    text-align: center;
    padding-left: 2.5rem;
    padding-right: 2.5rem;
  }
  #Guild .panel-title .level,
  #Message.list .panel-title .level,
  #Board.list .panel-title .level,
  #Favorite.list .panel-title .level,
  #FootPrint.list .panel-title .level,
  #Companies.list .panel-title .level,
  #Calendar.list .panel-title .level,
  #Message.search .panel-title .level,
  #Board.search .panel-title .level,
  #Favorite.search .panel-title .level,
  #FootPrint.search .panel-title .level,
  #Companies.search .panel-title .level,
  #Calendar.search .panel-title .level,
  #Message.list .frame-title .level,
  #Board.list .frame-title .level,
  #Favorite.list .frame-title .level,
  #FootPrint.list .frame-title .level,
  #Companies.list .frame-title .level,
  #Calendar.list .frame-title .level,
  #Message.search .frame-title .level,
  #Board.search .frame-title .level,
  #Favorite.search .frame-title .level,
  #FootPrint.search .frame-title .level,
  #Companies.search .frame-title .level,
  #Calendar.search .frame-title .level {
    width: auto;
    display: inline-block;
  }
  #Guild .character.orb,
  #Message.list .character.orb,
  #Board.list .character.orb,
  #Board.detail .character.orb,
  #Favorite.list .character.orb,
  #FootPrint.list .character.orb,
  #Companies.list .character.orb,
  #Calendar.list .character.orb,
  #Message.search .character.orb,
  #Board.search .character.orb,
  #Favorite.search .character.orb,
  #FootPrint.search .character.orb,
  #Companies.search .character.orb,
  #Calendar.search .character.orb {
    display: block;
    margin: 0 auto 1rem;
    height: 8.25rem;
    width: 8.25rem;
  }
}
@media screen and (min-width: 800px) {
  #Guild .panel-list .panel,
  #Message.list .panel-list .panel,
  #Board.list .panel-list .panel,
  #Board.detail .panel-list .panel,
  #Favorite.list .panel-list .panel,
  #FootPrint.list .panel-list .panel,
  #Companies.list .panel-list .panel,
  #Calendar.list .panel-list .panel,
  #Message.search .panel-list .panel,
  #Board.search .panel-list .panel,
  #Favorite.search .panel-list .panel,
  #FootPrint.search .panel-list .panel,
  #Companies.search .panel-list .panel,
  #Calendar.search .panel-list .panel,
  #Message.list .panel-list .frame,
  #Board.list .panel-list .frame,
  #Favorite.list .panel-list .frame,
  #FootPrint.list .panel-list .frame,
  #Companies.list .panel-list .frame,
  #Calendar.list .panel-list .frame,
  #Message.search .panel-list .frame,
  #Board.search .panel-list .frame,
  #Favorite.search .panel-list .frame,
  #FootPrint.search .panel-list .frame,
  #Companies.search .panel-list .frame,
  #Calendar.search .panel-list .frame {
    min-height: 9rem;
    padding-left: 8.5rem;
    padding-right: 2.5rem;
  }
  #Guild .panel-list .character.orb,
  #Message.list .panel-list .character.orb,
  #Board.list .panel-list .character.orb,
  #Board.detail .panel-list .character.orb,
  #Favorite.list .panel-list .character.orb,
  #FootPrint.list .panel-list .character.orb,
  #Companies.list .panel-list .character.orb,
  #Calendar.list .panel-list .character.orb,
  #Message.search .panel-list .character.orb,
  #Board.search .panel-list .character.orb,
  #Favorite.search .panel-list .character.orb,
  #FootPrint.search .panel-list .character.orb,
  #Companies.search .panel-list .character.orb,
  #Calendar.search .panel-list .character.orb {
    position: absolute;
    height: 5.825rem;
    width: 5.825rem;
    top: 1.5rem;
    left: 1.5rem;
  }
}
#Calendar .date-index {
  height: 7.25rem;
  width: 7.25rem;
  color: #ffffff;
  border: solid 1px #ffffff;
  border-radius: 0.5rem;
  padding: 0.25rem;
  margin: 0 auto;
  text-align: center;
}
#Calendar .date-index span {
  display: inline-block;
  font-size: 2.5rem;
  margin: 0.5rem 0;
}
#Calendar .date-index time {
  display: block;
}
@media screen and (min-width: 800px) {
  #Calendar .date-index {
    position: absolute;
    top: 1rem;
    left: 1rem;
    text-align: center;
    margin: 0;
    padding: 0;
  }
}
#Calendar .date-list > li {
  list-style: none;
  position: relative;
}
@media screen and (min-width: 800px) {
  #Calendar .date-list > li {
    padding-top: 0;
    padding-bottom: 0;
    padding-left: 8.125rem;
  }
}
#Calendar .date-list > li .panel-list .panel,
#Calendar .date-list > li .panel-list .frame {
  background: none;
}
#Calendar .date-list > li .panel-list .panel:hover,
#Calendar .date-list > li .panel-list .panel:active,
#Calendar .date-list > li .panel-list .frame:hover,
#Calendar .date-list > li .panel-list .frame:active {
  opacity: 0.65;
}
#Calendar .date-list > li .panel-list .panel:before,
#Calendar .date-list > li .panel-list .frame:before {
  display: none;
}
#Calendar .date-list > li .panel-list li::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1rem;
  margin: 0 auto;
  height: 2px;
  width: 90%;
  background-image: linear-gradient(to right, rgba(170, 170, 170, 0) 0%, #aaaaaa 20%, #aaaaaa 80%, rgba(170, 170, 170, 0) 100%), linear-gradient(to right, rgba(144, 148, 117, 0) 0%, #909475 20%, #909475 80%, rgba(144, 148, 117, 0) 100%), linear-gradient(to right, rgba(84, 46, 0, 0) 0%, #542e00 20%, #542e00 80%, rgba(84, 46, 0, 0) 100%);
  background-repeat: no-repeat;
  background-size: auto 1px;
  background-position: center 2px, center, center 0px;
}
@media screen and (min-width: 800px) {
  #Calendar .date-list > li .panel-list li::before {
    width: 80%;
  }
}
#Calendar .date-list > li .panel-list li:last-child::before {
  display: none;
}
#Message .scroller {
  overflow-y: scroll;
  overflow-x: visible;
}
@media screen and (min-width: 800px) {
  #Message .scroller {
    height: calc(100vh - 625px);
    min-height: 425px;
  }
}
@media screen and (max-width: 799px) {
  #Message .scroller {
    height: calc(100vh - 425px);
    min-height: 325px;
  }
}
#Message ol.timeline {
  list-style: none;
  max-width: 1000px;
  margin: 0 auto;
}
#Message ol.timeline > li {
  display: block;
  position: relative;
  padding: 0.5rem 0;
  margin: 1rem auto;
  min-height: 6rem;
}
#Message ol.timeline > li .balloon,
#Message ol.timeline > li time {
  display: inline-block;
  vertical-align: bottom;
  direction: ltr;
}
#Message ol.timeline > li .balloon {
  margin: 0;
}
@media screen and (max-width: 1279px) {
  #Message ol.timeline > li .balloon {
    width: 100%;
  }
}
@media screen and (min-width: 800px) {
  #Message ol.timeline > li .balloon {
    max-width: 580px;
  }
}
@media screen and (max-width: 799px) {
  #Message ol.timeline > li .balloon {
    max-width: 460px;
  }
}
#Message ol.timeline > li .balloon .tag {
  font-size: 0.8125rem;
}
#Message ol.timeline > li time {
  color: #ffffff;
  margin: 0 0.25rem;
}
#Message ol.timeline > li .character.orb {
  position: absolute;
  top: 0;
  height: 5.825rem;
  width: 5.825rem;
}
@media screen and (max-width: 799px) {
  #Message ol.timeline > li .character.orb {
    top: 0.25rem;
    height: 4.25rem;
    width: 4.25rem;
  }
}
#Message ol.timeline > li.to {
  text-align: right;
  padding-right: 7rem;
}
@media screen and (max-width: 799px) {
  #Message ol.timeline > li.to {
    padding-right: 5.5rem;
    padding-left: 0.5rem;
  }
}
#Message ol.timeline > li.to .character.orb {
  right: 0;
}
#Message ol.timeline > li.from {
  direction: rtl;
  text-align: left;
  padding-left: 7rem;
}
@media screen and (max-width: 799px) {
  #Message ol.timeline > li.from {
    padding-left: 5.5rem;
    padding-right: 0.5rem;
  }
}
#Message ol.timeline > li.from .character.orb {
  left: 0;
}
#News .panel-title,
#Board .panel-title,
#Guild .panel-title,
#News .frame-title,
#Board .frame-title,
#Guild .frame-title
{
  display: block;
  margin-top: 0.25em;
}
#News .panel .tag-list,
#Board .panel .tag-list,
#News .panel time,
#Board .panel time,
#News .frame .tag-list,
#Board .frame .tag-list,
#News .frame time,
#Board .frame time {
  display: inline-block !important;
}
#News.detail .panel-title,
#Board.detail .panel:not(.in-panel) > .panel-title,
#Guild.detail .panel-title,
#News.detail .frame-title,
#Board.detail .frame-title ,
#Guild.detail .frame-title
{
  text-align: center;
}
#News.detail .panel-content,
#Board.detail .panel-content,
#Guild.detail .panel-content,
#News.detail .frame-content,
#Board.detail .frame-content,
#Guild.detail .frame-content
{
  width: 90%;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 1280px) {
  #News.detail .panel-content,
  #Board.detail .panel:not(.in-panel) > .panel-content,
  #Guild.detail .panel-content,
  #News.detail .frame-content,
  #Board.detail .frame-content ,
  #Guild.detail .frame-content
  {
    width: 80%;
  }
}
@media screen and (max-width: 1279px) {
  #MyPage .inner {
    max-width: 600px;
  }
}
#MyPage .company-character {
  position: relative;
  display: block;
  width: 100%;
  z-index: -1;
}
@media screen and (max-width: 799px) {
}
@media screen and (min-width: 1280px) {
  #MyPage .company-character {
    position: fixed;
    z-index: -1;
    right: 0;
    left: 0;
    top: 0;
    bottom: 0;
    margin: 0 auto;
    overflow: hidden;
    width: 1280px;
  }
}
#MyPage .company-character img {
  display: block;
}
@media screen and (min-width: 1280px) {
  #MyPage .company-character img {
    position: absolute;
    height: 1200px;
    top: 5vh;
    left: 30%;
  }
}
@media screen and (max-width: 1279px) {
  #MyPage .company-character img {
    max-width: 100%;
  }
}
#MyPage .company-info {
  position: relative;
}
@media screen and (min-width: 1280px) {
  #MyPage .company-info {
    width: 50%;
  }
}
#MyPage .company-name {
  position: relative;
  z-index: 10;
}
#MyPage .company-name .panel,
#MyPage .company-name .frame {
  text-align: center;
  margin: 0 auto;
  padding-top: 2rem;
  padding-bottom: 2rem;
  text-shadow: -1px -1px 4px rgba(84, 46, 0, 0.6), -1px 0 4px rgba(84, 46, 0, 0.6), -1px 1px 4px rgba(84, 46, 0, 0.6), 0 -1px 4px rgba(84, 46, 0, 0.6), 0 1px 4px rgba(84, 46, 0, 0.6), 1px -1px 4px rgba(84, 46, 0, 0.6), 1px 0 4px rgba(84, 46, 0, 0.6), 1px 1px 4px rgba(84, 46, 0, 0.6);
  font-size: 1.25rem;
  background-color: #6b2626;
}
@media screen and (min-width: 800px) and (max-width: 1279px) {
  #MyPage .company-name {
    margin: 0 auto 3.25rem auto;
  }
}
@media screen and (max-width: 799px) {
  #MyPage .company-name {
    left: 0;
    right: 0;
    margin: 0 auto 3.25rem auto;
    width: 90%;
  }
}
@media screen and (min-width: 1280px) {
  #MyPage .company-name {
    position: fixed;
    margin-left: 645px;
    bottom: 15%;
    width: 25rem;
  }
}
#MyPage .company-name .level {
  position: absolute;
  bottom: -0.85rem;
  right: -0.5rem;
  max-width: 15rem;
}
#MyPage #Dinar + .modal time,
#MyPage #Dinar + .loot time {
  text-align: center;
  font-size: 1.25rem;
}
@media screen and (max-width: 799px) {
  #MyPage #Dinar + .modal .controller.selects .btn,
  #MyPage #Dinar + .loot .controller.selects .btn {
    display: block;
    margin-bottom: 1rem;
  }
}
#Companies .frame-content {
  width: 90%;
}
@media screen and (min-width: 800px) {
  #Companies .frame-content {
    min-height: 7.5rem;
  }
}
#Companies .frame-content p {
  font-size: 0.925rem;
}
@media screen and (max-width: 360px -1) {
  #Companies .frame-content p {
    overflow: hidden;
    height: 5.55em;
  }
}
#Companies .company {
  padding: 0 2rem;
  margin: 0 -2rem;
}
#Companies .company-list {
  overflow: visible;
}
#Companies .company-list > li {
  list-style: none;
}
#Companies .company-list > li .frame {
  height: calc(100% - 2rem);
  padding-bottom: 2rem;
}
#Companies .company-list > li .frame .company-character {
  width: 90%;
  left: 0;
  right: 0;
  margin: 0 auto;
  overflow: hidden;
  z-index: 0;
}
@media screen and (max-width: 799px) {
  #Companies .company-list > li .frame .company-character {
    max-width: 500px;
  }
}
#Companies .company-list > li .frame .company-character::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(to top, #4e483e 0%, #4e483e 45%, rgba(78, 72, 62, 0) 55%);
  z-index: 10;
}
#Companies .company-list > li .frame .company-character img {
  width: 100%;
  margin: auto;
  z-index: -1;
}
#Companies .company-list > li .frame .company-name {
  min-width: auto;
  margin-left: auto;
  margin-right: auto;
  z-index: 10;
  text-align: center;
}
@media screen and (max-width: 799px) {
  #Companies .company-list > li .frame .company-name {
    width: 100%;
    max-width: 500px;
  }
}
@media screen and (min-width: 800px) {
  #Companies .company-list > li .frame .company-name {
    margin-left: -5%;
    width: 110%;
  }
}
#Companies .company-list > li .frame .company-name .panel,
#Companies .company-list > li .frame .company-name .frame {
  padding-top: 2rem;
  padding-bottom: 2rem;
  margin-top: 0;
  min-width: auto;
  text-shadow: -1px -1px 4px rgba(84, 46, 0, 0.6), -1px 0 4px rgba(84, 46, 0, 0.6), -1px 1px 4px rgba(84, 46, 0, 0.6), 0 -1px 4px rgba(84, 46, 0, 0.6), 0 1px 4px rgba(84, 46, 0, 0.6), 1px -1px 4px rgba(84, 46, 0, 0.6), 1px 0 4px rgba(84, 46, 0, 0.6), 1px 1px 4px rgba(84, 46, 0, 0.6);
  background-color: #6b2626;
}
@media screen and (min-width: 800px) {
  #Companies .company-list > li .frame .company-name .panel,
  #Companies .company-list > li .frame .company-name .frame {
    font-size: 1rem;
  }
}
#Companies .company-list > li .frame .company-name .level {
  position: absolute;
  bottom: -0.75rem;
  right: -0.5rem;
  max-width: 10rem;
}
#Companies .company-list > li .frame .controller {
  position: absolute;
  bottom: 1rem;
  left: 0;
  right: 0;
  margin: auto;
}
#Companies .company-list > li .frame-content {
  margin-bottom: 1rem;
}
#Profile.edit .star-chip label {
  cursor: pointer;
}
#Profile.edit .star-chip label:hover::before {
  color: #caa846;
}
#Bonus.exp .inner {
  text-align: center;
}
#Bonus.exp .inner #treasure {
  position: relative;
  max-width: 500px;
  margin: 2.5rem auto;
}
#Bonus.exp .inner #treasure img {
  position: relative;
  z-index: 10;
}
#Bonus.exp .inner #treasure img:last-child {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  opacity: 0;
  z-index: 5;
}
#Bonus.exp #cover:checked ~ #treasure img {
  transition: opacity 1.5s ease;
}
#Bonus.exp #cover:checked ~ #treasure img:first-child {
  opacity: 0;
}
#Bonus.exp #cover:checked ~ #treasure img:last-child {
  opacity: 1;
}
.loot-container {
  width: 80%;
  min-width: 280px;
}
.loot .frame {
  max-width: 600px;
  margin: 0 auto;
  min-height: 300px;
  text-align: center;
}
.loot .frame-content {
  margin-top: 0.25rem;
  font-size: 1.5rem;
}
.loot .frame-content strong {
  display: block;
  font-family: 'Tangerine', cursive;
  font-size: 10rem;
}
/*****************************************************************
 GLIDE
*****************************************************************/
.glide {
  padding-left: 0;
  padding-right: 0;
}
.glide__slides {
  flex-wrap: wrap;
}
.glide__slide {
  padding: 0 0.5rem;
  height: auto;
  display: flex;
  align-items: center;
}
@media screen and (min-width: 800px) {
  .glide__slide {
    padding: 0 1rem;
  }
}
.glide__arrows {
  position: absolute;
  top: 50%;
  z-index: 10;
  width: 100%;
}
.glide__arrow {
  position: absolute;
}
.glide__arrow--left {
  left: 0.5rem;
}
.glide__arrow--right {
  right: 0.5rem;
}
.glide__arrow i {
  display: inline-block;
  min-width: 0.5rem;
  font-style: normal;
  transform: scale(1.5) translateY(-7.5%);
}


/* 20200908追加 */
a.a_link,
#Board.detail .panel-content a {
  color: #3776de;
}
.comment_media {
  flex: 0 0 100%;
  list-style: none;
}
@media screen and (min-width: 800px) {
  .panel .panel-inner-center {
    padding-right: 6rem;
  }
}

#Guild .list-character-orb {
  display: flex;
  flex-wrap: wrap;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  margin: 1rem 0;
}

#Guild .list-character-orb .character {
  margin: 0 0.25rem 0.25rem;
  height: 5.25rem;
  width: 5.25rem;
}

.btn .badge.btn-badge {
  position: absolute;
  top: -0.2rem;
  right: -0.2rem;
  z-index: 100;
  height: 1.25rem;
  width: 1.25rem;
  line-height: 1.25rem;
}
.btn .badge.btn-badge::before {
  height: 1.0rem;
  width: 1.0rem;
}
.btn .badge.btn-badge::after {
  height: calc(0.75rem);
  width: calc(0.75rem);
}

.in-panel-content {
  z-index: 1;
  position: relative;
  margin: 1.5rem 0;
}

.panel.in-panel {
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
}

.form_comment_wrap textarea {
  margin-bottom: 0;
}
.form_comment_wrap input[type="file"] {
  display: block;
  margin-top: 0;
}

#Profile input[type="file"].upload_file {
  display: block;
}

#tutorial_button {
  position: fixed;
  bottom: 10vh;
  right: 20px;
  z-index: 800;
}
#tutorial_button.mypage{
  position: static;
  text-align: right;
  padding-right: 10%;
}
#tutorial_button .orb span {
  margin-top: 50%;
  font-weight: 500;
  font-size: 0.625rem;
}

#tutorial_button .orb i {
  font-size: 1.25rem;
}

@media screen and (min-width: 800px) {
  #tutorial_button .orb span {
    font-size: 0.625rem;
  }
}
@media screen and (max-width: 799px) {
  #tutorial_button .orb {
    height: 57.375px;
    width: 57.375px;
  }
}
@media screen and (min-width: 800px) and (max-width: 1279px) {
  #tutorial_button .orb {
    height: 64.125px;
    width: 64.125px;
  }
}
@media screen and (min-width: 1280px) {
  #tutorial_button  {
    right: calc(((100vw - 1280px) / 2) + 10px);
  }
  #tutorial_button .orb {
    height: 74.25px;
    width: 74.25px;
  }
}

.modal.tutorial_modal .panel{
  max-width: 1100px;
  width: 100%;
  padding-top: 0.75rem;
}
@media screen and (max-width: 799px) {
  .modal.tutorial_modal .modal-container .panel{
    width: 90%;
    padding-left: 0.5rem!important;
    padding-right: 0.5rem!important;
  }
}
.modal.tutorial_modal  .tutorial-swiper-container {
  width: 100%;
}
.modal.tutorial_modal  .tutorial-swiper-container .pc ,
.modal.tutorial_modal  .tutorial-swiper-container .sp {
  display: none;
}
@media screen and (min-width: 800px) {
  .modal.tutorial_modal  .tutorial-swiper-container .pc {
    display: inline-block;
  }
}
@media screen and (max-width: 799px) {
  .modal.tutorial_modal  .tutorial-swiper-container .sp {
    display: inline-block;
  }
}
.modal.tutorial_modal .swiper-button-next-orb,
.modal.tutorial_modal .swiper-button-prev-orb{
  position: absolute;
  top: 50%;
  z-index: 10;
  cursor: pointer;
  width: 3rem;
  height: 3rem;
}
@media screen and (max-width: 799px) {
  .modal.tutorial_modal .swiper-button-next-orb,
  .modal.tutorial_modal .swiper-button-prev-orb{
    /*top: unset;*/
    /*bottom: 10px;*/
  }
}
.modal.tutorial_modal .swiper-button-next-orb i,
.modal.tutorial_modal .swiper-button-prev-orb i{
  font-size: 1.25rem;
  top: 32%;
}
.modal.tutorial_modal .swiper-button-next-orb{
  right: 0;
}
.modal.tutorial_modal .swiper-button-prev-orb{
  left: 0;
}
.modal.tutorial_modal .swiper-pagination {
  position: relative;
  margin-top: 1rem;
}
.modal.tutorial_modal  .swiper-pagination-bullet-active {
  background: #ffffff;
}
.modal.tutorial_modal .slide-img {
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}
@media screen and (min-width: 800px) {
  .modal.tutorial_modal .slide-img {   height: 65vh; }
  /*マイページ*/
  .modal.tutorial_modal .slide-mypage-1 { background-image: url("../img/tutorial/mypage_1.jpg") }
  .modal.tutorial_modal .slide-mypage-2 { background-image: url("../img/tutorial/mypage_2.jpg") }
  .modal.tutorial_modal .slide-mypage-3 { background-image: url("../img/tutorial/mypage_3.jpg") }
  /*プロフィール*/
  .modal.tutorial_modal .slide-profile-1 { background-image: url("../img/tutorial/mypage_1.jpg") }
  .modal.tutorial_modal .slide-profile-2 { background-image: url("../img/tutorial/mypage_2.jpg") }
  .modal.tutorial_modal .slide-profile-3 { background-image: url("../img/tutorial/mypage_3.jpg") }
  /*お知らせ*/
  .modal.tutorial_modal .slide-notice-1 { background-image: url("../img/tutorial/notice_1.jpg") }
  .modal.tutorial_modal .slide-notice-2 { background-image: url("../img/tutorial/notice_2.jpg") }
  /*メッセージ*/
  .modal.tutorial_modal .slide-message-1 { background-image: url("../img/tutorial/message_1.jpg") }
  .modal.tutorial_modal .slide-message-2 { background-image: url("../img/tutorial/message_2.jpg") }
  /*あしあと*/
  .modal.tutorial_modal .slide-footprint-1 { background-image: url("../img/tutorial/footprint_1.jpg") }
  /*企業検索*/
  .modal.tutorial_modal .slide-company_search-1 { background-image: url("../img/tutorial/company_search_1.jpg") }
  /*お気に入り企業*/
  .modal.tutorial_modal .slide-favorite_company-1 { background-image: url("../img/tutorial/favorite_company_1.jpg") }
  /*注目企業*/
  .modal.tutorial_modal .slide-feature_company-1 { background-image: url("../img/tutorial/feature_company_1.jpg") }
  /*掲示板*/
  .modal.tutorial_modal .slide-bulletin_board-1 { background-image: url("../img/tutorial/bulletin_board_1.jpg") }
  .modal.tutorial_modal .slide-bulletin_board-2 { background-image: url("../img/tutorial/bulletin_board_2.jpg") }
  /*トラブル報告*/
  .modal.tutorial_modal .slide-contact-1 { background-image: url("../img/tutorial/contact_1.jpg") }
  /*ギルド*/
  .modal.tutorial_modal .slide-guild-1 { background-image: url("../img/tutorial/guild_1.jpg") }
  .modal.tutorial_modal .slide-guild-2 { background-image: url("../img/tutorial/guild_2.jpg") }
  .modal.tutorial_modal .slide-guild-3 { background-image: url("../img/tutorial/guild_3.jpg") }
}
@media screen and (max-width: 799px) {
  .modal.tutorial_modal .slide-img {   height: 65vh; }
  /*マイページsp*/
  .modal.tutorial_modal .slide-mypage-1 { background-image: url("../img/tutorial/mypage_1_sp.jpg") }
  .modal.tutorial_modal .slide-mypage-2 { background-image: url("../img/tutorial/mypage_2_sp.jpg") }
  .modal.tutorial_modal .slide-mypage-3 { background-image: url("../img/tutorial/mypage_3_sp.jpg") }
  /*プロフィールsp*/
  .modal.tutorial_modal .slide-profile-1 { background-image: url("../img/tutorial/mypage_1_sp.jpg") }
  .modal.tutorial_modal .slide-profile-2 { background-image: url("../img/tutorial/mypage_2_sp.jpg") }
  .modal.tutorial_modal .slide-profile-3 { background-image: url("../img/tutorial/mypage_3_sp.jpg") }
  /*お知らせsp*/
  .modal.tutorial_modal .slide-notice-1 { background-image: url("../img/tutorial/notice_1_sp.jpg") }
  .modal.tutorial_modal .slide-notice-2 { background-image: url("../img/tutorial/notice_2_sp.jpg") }
  /*メッセージsp*/
  .modal.tutorial_modal .slide-message-1 { background-image: url("../img/tutorial/message_1_sp.jpg") }
  .modal.tutorial_modal .slide-message-2 { background-image: url("../img/tutorial/message_2_sp.jpg") }
  /*あしあとsp*/
  .modal.tutorial_modal .slide-footprint-1 { background-image: url("../img/tutorial/footprint_1_sp.jpg") }
  /*企業検索sp*/
  .modal.tutorial_modal .slide-company_search-1 { background-image: url("../img/tutorial/company_search_1_sp.jpg") }
  /*お気に入り企業sp*/
  .modal.tutorial_modal .slide-favorite_company-1 { background-image: url("../img/tutorial/favorite_company_1_sp.jpg") }
  /*注目企業sp*/
  .modal.tutorial_modal .slide-feature_company-1 { background-image: url("../img/tutorial/feature_company_1_sp.jpg") }
  /*掲示板sp*/
  .modal.tutorial_modal .slide-bulletin_board-1 { background-image: url("../img/tutorial/bulletin_board_1_sp.jpg") }
  .modal.tutorial_modal .slide-bulletin_board-2 { background-image: url("../img/tutorial/bulletin_board_2_sp.jpg") }
  /*トラブル報告sp*/
  .modal.tutorial_modal .slide-contact-1 { background-image: url("../img/tutorial/contact_1_sp.jpg") }
  /*ギルドsp*/
  .modal.tutorial_modal .slide-guild-1 { background-image: url("../img/tutorial/guild_1_sp.jpg") }
  .modal.tutorial_modal .slide-guild-2 { background-image: url("../img/tutorial/guild_2_sp.jpg") }
  .modal.tutorial_modal .slide-guild-3 { background-image: url("../img/tutorial/guild_3_sp.jpg") }
}

#Guild .guild_profile{
  display: flex;
  padding-right: 2.5rem;
}

#Guild .guild_profile_owner {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  flex: 0 0 5.5rem;
}
#Guild .guild_profile_owner .character {
  width: 4.5rem;
  height: 4.5rem;
}
#Guild .guild_profile_owner .company_name {
  width: 100%;
}

/*20201207*/
/*コメントボタン*/
.in-panel-content.accordion-content .accordion-control{
  text-align: right;
}

.other-config-setting .panel-content .field{
  margin: 0 auto 1.5rem auto;
}

/*マイページ 資料添付*/
.file-list{
  width: 90%;
  margin: 0 auto;
  z-index: 10;
  list-style: none;
}
@media screen and (min-width: 1280px) {
  .file-list {
    width: 80%;
  }
}

.file-list li i{
  padding-right: 0.5rem;
  text-shadow: -1px -1px 4px rgba(84, 46, 0, 0.6), -1px 0 4px rgba(84, 46, 0, 0.6), -1px 1px 4px rgba(84, 46, 0, 0.6), 0 -1px 4px rgba(84, 46, 0, 0.6), 0 1px 4px rgba(84, 46, 0, 0.6), 1px -1px 4px rgba(84, 46, 0, 0.6), 1px 0 4px rgba(84, 46, 0, 0.6), 1px 1px 4px rgba(84, 46, 0, 0.6);
}