body {
  font-family: "Hiragino Sans W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  text-align: center;
  margin: 0;
  padding: 5px;
  font-size: 16px;
  color: #2c3e50;
}

        ul {
          padding: 0;
          margin: 0;
        }

        .about {
          /*about全体の設定*/
          text-align: center;
          padding: 0 0 0px;
          font-size:14px;
        }

        .titleLink {
          /*mainMenu全体の設定*/
          font-size: 17px;
          text-align: center;
          padding: 15px;
          font-weight: bold;
        }

        .balloon2 {
          text-align: center;
        }

        .balloon2-top {
          border: solid 2px #e0edff;
          text-align: center;
          position: relative;
          display: inline-block;
          align-items: center;
          margin: 8px 0;
          padding: 7px 10px;
          min-width: 120px;
          max-width: 100%;
          color: #555;
          font-size: 14px;
        }

        .balloon2-top:before {
          content: "";
          position: absolute;
          top: -30px;
          left: 50%;
          margin-left: -15px;
          border: 15px solid transparent;
          border-bottom: 15px solid #e0edff;
        }

        .page_info {
          text-align: center;
          position: relative;
          display: inline-block;
          align-items: center;
          padding: 0px 10px 18px;
          min-width: 120px;
          max-width: 100%;
          color: #555;
          font-size: 14px;
        }

        .wrap {
          width: 100%;
          display: block;
          background: #fff;
        }
        /*main部分の設定*/

        .main {
          max-width: 600px;
          margin: 0 auto;
        }

        .mainHeader {
          position: relative;
          padding: 30px 0 0;
          text-align: center;
        }

        .mainHeader_info {
          font-size: 20px;
          margin: 0 0 5px;
        }

        .info{
          padding: 10px;
          margin: 10px;
          text-align: center;
line-height: 2em;
        }


.balloon3 {
  text-align: center;
}

.balloon3-top {
  border: solid 2px #e0edff;
  text-align: center;
  position: relative;
  display: inline-block;
  align-items: center;
  margin: 8px 0;
  padding: 7px 10px;
  min-width: 120px;
  max-width: 100%;
  color: #555;
  font-size: 14px;
}

.balloon3-top:before {
  content: "";
  position: absolute;
  bottom: -30px;
  left: 50%;
  margin-left: -15px;
  border: 15px solid transparent;
  border-top: 15px solid #e0edff;
}

.color1 {
  background-color: #ffcabf;
}

.color2 {
  background-color: #ffff80;
}

.color3 {
  background-color: #d8f255;
}

/* 
.color5 {
  background-color: #ffca80;
}

.color8 {
  background-color: #66bfff;
}
*/

.color4 {
  background-color: #bfe4ff;
}

.color6 {
  background-color: #77d9a8;
}

.color7 {
  background-color: #c9ace6;
}

.color9 {
  background-color: #808080;
}

.m-plus-rounded-1c-regular {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 400;
  font-style: normal;
  src: url('/fonts/MPLUSRounded1c-Regular.ttf') format('ttf');
}

ul {
  padding-left: 5px;
}

a:link {
  color: #7c96ac;
  text-decoration: underline;
}

a:hover {
  color: #7c96ac;
  text-decoration: none;
}

a:visited {
  color: #6e7574;
  text-decoration: none;
}

        .about {
          text-align: center;
          padding: 0 0 0px;
          font-size:14px;
        }

.attention label {
  text-align: center;
  height: 25px;
  display: block;
  padding: 3px;
  font-weight: bold;
  cursor: pointer;
}

.attention input[type="checkbox"] {
  display: none;
}

/* クリックしたら表示される領域 */

.attention .attention_child {
  height: 0;
  padding: 0;
  overflow: hidden;
  margin-bottom: 10px;
}

.switch:checked+.attention_child {
  height: auto;
}

.attention {
  margin: 5px 0;
}

.attention_list {
  font-size: 14px;
  position: relative;
  display: table;
  padding: 1px;
}

.attention-align-center {
  display: flex;
  align-items: center;
  flex-direction: column;
}

.centered-heading {
  margin-left: 1em;
  margin-right: auto;
  text-align: center;
  display: table;
  font-weight: bold;
}

.page-title {
  font-size: 26px;
  text-align: center;
  margin: 0 auto;
  display: table;
}

/* 再生成ボタン */

.reload_btn {
  position: relative;
  padding: 10px 15px;
  width: 170px;
  border: none;
  border-radius: 5px;
  color: #2c3e50;
  font-size: 16px;
  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.3);
  cursor: pointer;
}

.reload_button_area {
  text-align: center;
  margin-top:0.5em;
}

/* シート本体 */

.sheet-container {
  width: 450px;
  max-width: 100%;
  box-sizing: border-box;
  padding: 10px 20px 8px;
  background-color: #ffffff;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  display: inline-block;
  overflow: hidden;
  border: solid 1.5px #c8c8cb;
}

.sheet-printout{
  width: 360px;
  max-width: 100%;
  box-sizing: border-box;
  display: inline-block;
  text-align: center;
  font-size: 0;
}

.title {
  font-size: 22px;
  font-weight: bold;
  padding: 0px 0px 10px;
}

table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 3px;
  table-layout: fixed;
  overflow: hidden;
  background-color: #ffffff;
}

th,
td {
  padding: 10px;
  word-break: break-word;
  height: 75px;
  text-align: center;
  vertical-align: middle;
  background-color: #fff;
  font-size: 18px;
  cursor: pointer;
  transition: background-color 0.3s;
  border: solid 1.5px #c8c8cb;
  border-radius: 8px;
}

.save_button_area {
  text-align: center;
}

.save_button {
  border: none;
  padding: 10px 20px;
  margin: 15px 0px 0px;
  font-size: 16px;
  cursor: pointer;
  color: #2c3e50;
  border-radius: 5px;
  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.3);
}

.imagePreview {
  margin: 15px 0px;
  font-size: 12px;
  width: 350px;
  max-width: 100%;
  display: inline-block;
  box-sizing: border-box;
  color: #c8c8cb;
}

.sign {
  text-align: right;
  font-size: 10px;
  color: #c8c8cb;
  display: flex;
  justify-content: right;
}

.freebox {
  border: none;
  background: #ffffff;
  text-align: center;
  color: #2c3e50;
  width: 350px;
  max-width: 100%;
  box-sizing: border-box;
  font-size: 18px;
}

.freebox_name {
  border: none;
  background: #ffffff;
  text-align: right;
  color: #2c3e50;
  width: 95%;
  font-size: 15px;
}

.list-item_notice {
  opacity: 1;
  margin-top: 3px;
  margin-bottom: 6px;
  font-size: 15px;
  list-style-type: none;
}

.notice-list {
  display: inline-block;
  text-align: left;
}

.notice {
  margin: 1em 0 0;
}

        #page_top {
          width: 80px;
          height: 80px;
          position: fixed;
          right: 0;
          bottom: 0;
          opacity: 0.6;
        }

        #page_top a {
          width: 75px;
          height: 75px;
          text-decoration: none;
        }

        #page_top a::before {
          font-weight: 900;
          font-size: 50px;
        }

        /*戻る*/
        #back {
          padding: 5px 0px 2px 0px;
        }

/* リセットCSS */
hr {
  height: 0;
  margin: 0;
  padding: 0;
  border: 0;
}
hr.line {
  border: none;
  border-top: 1px dashed #00284f;
  width: 350px;
  max-width: 100%;
  display: inline-block;
}

/* モバイル用調整 */
@media screen and (max-width: 480px) {

  td,
  th {
    height: 75px;
    font-size: 18px;
    padding: 6px;
  }
}