* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
*:before, *:after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

@font-face {
  font-family: customFont;
  src: url('https://content.jorte.com/api/v1/files/font/preset/JorteGothic.woff2') format('woff'),
  url('https://content.jorte.com/api/v1/files/font/preset/JorteGothic.ttf') format('truetype');
  
  font-display: swap;
}

body,
body *,
option {
  font-family: customFont, 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, sans-serif;
}

html {
  font-size: 100%;
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
}

html,
body,
header div {
  height: 100%;
}
nav {
  width: 100%;
}

body, h1 {
  margin: 0;
}

p {
  margin: 0;
  letter-spacing: normal;
  word-spacing: normal;
  text-rendering: auto;
}
a {
  text-decoration: none;
  color: rgb(61, 146, 201);
}
a:hover,
a:focus {
  text-decoration: none;
}

/* common
--------------------------------------------------- */
.btn {
  border-color: rgba(110,128,200,1.0);
  background-color: rgba(70,82,120,1.0);
  color: rgba(248,248,248,1.0);
  text-shadow: 0 0 0.5px;

  display: inline-block;
  margin-bottom: 0;
  text-align: center;
  vertical-align: middle;
  touch-action: manipulation;
  cursor: pointer;
  border: 1px solid #ccc;
  padding: 0.5rem 1rem;
  border-radius: 4px;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
.row {
  margin-top: 1rem;
  width: 100%;
}
.center {
  text-align: center;
}

h2.accordion-title {
  font-size: 18px;
  font-weight: 400;
  line-height: 28px;
  margin: 0 15px;
}

div.triangle {
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 14px 0 14px 24.2px;
  border-color: transparent transparent transparent #404040;
  margin: 0 3px 0 5px;
  transition: 0.2s;
}
div.triangle.open {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 24.2px 14px 0 14px;
  border-color: #404040 transparent transparent transparent;
  margin: 3px 1px 0 3px;
  transition: 0.2s;
}

/* header
--------------------------------------------------- */
header {
  position: absolute;
  width: 100%;
  z-index: 99;
}
header * {
  background-color: rgba(88,88,88,1.0);
  color: rgba(230,230,230,1.0);
  text-shadow: 0 0 0.5px;
}
header > div {
  width: 100%;
  height: 32px;
}
header nav {
  float: left;
  height: 100%;
}
header ul {
  height: 100%;
  width: 100%;
  padding: 0;
  margin: 0;
  list-style: none;
}
header ul li {
  height: 100%;
  position: relative;
  line-height: 32px;
  cursor: pointer;
  display: inline-block;
}
header ul li:first-of-type {
  vertical-align: top;
}
header ul li:last-of-type {
  float: right;
  vertical-align: middle;
  padding: 0 0.5rem;
}
header path {
  fill: rgba(230,230,230,1.0);
}

/* contents
--------------------------------------------------- */
body {
  /* background-color: #e7edf1; */
  color: rgba(64,64,64,1.0);
}

.contents {
  position: relative;
  width: 100%;
  overflow: hidden;
}

section {
  position: relative;
  overflow: auto;
  height: 100%;
  width: 100%;
  padding-top: 32px;
}

.container {
	margin-right: auto;
	margin-left: auto;
  padding: 5px 15px 15px 15px;
}
.container:before, .container:after {
	content: " ";
	display: table;
}
.container:after {
	clear: both;
}
@media  (min-width: 768px) {
	.container {
		width: 750px;
	}
}
@media  (min-width: 992px) {
	.container {
		width: 970px;
	}
}
@media  (min-width: 1200px) {
	.container {
		width: 1170px;
	}
}

/* calendar list
--------------------------------------------------- */
.cal-list {
  display: flex;
  flex-direction: column;
  border: 1px solid #ddd;
  border-radius: 4px;
}
.cal-item {
  width: 100%;
  padding: 15px;
  border-bottom: 1px solid #ddd;
  cursor: pointer;
  display: flex;
}

.cal-item.close {
  opacity: 0;
  height: 0;
  padding: 0 15px;
  border: 0;
  transition: 0.2s;
}
.cal-item.open {
  opacity: 1;
  height: auto;
  padding: 15px;
  border-bottom: 1px solid #ddd;
  transition: 0.2s;
}

.accordion:last-of-type .cal-items .cal-item:last-of-type {
  border: none;
}
.accordion:last-of-type .cal-items .cal-item:first-of-type {
  border-top: 1px solid #ddd;
}
.accordion:last-of-type > .cal-item {
  border: none;
}

.cal-item-left {
  width: 2rem;
  margin-top: 7px;
}
.cal-item-center {
  width: calc(100% - 2rem - 15%);
  padding-left: 15px;
}
.cal-item-right {
  width: 15%;
  text-align: right;
  margin-top: 7px;
}

.cal-title {
  font-weight: 400;
  font-size: 18px;
  line-height: 28px;
}
.cal-title span.single {
  line-height: 2.9rem;
}
.cal-title, .cal-summary {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.fontcolor_square {
  display:inline-block;
  border-radius: 4px;
}
.cal-item .fontcolor_square {
  width: 32px;
  height: 32px;
  background-color: rgba(32,160,96,1.0);
}

.checkmark {
  display:inline-block;
  width: 32px;
  height:32px;
  -ms-transform: rotate(45deg); /* IE 9 */
  -webkit-transform: rotate(45deg); /* Chrome, Safari, Opera */
  transform: rotate(45deg);
}

.checkmark_circle {
  position: absolute;
  width: 32px;
  height: 32px;
  background-color: rgba(32,160,96,1.0);
  border-radius: 16px;
  left:0;
  top:0;
}

.checkmark_stem {
  position: absolute;
  width: 4px;
  height: 15px;
  background-color: #fff;
  left: 15px;
  top: 7px;
  border-radius: 2px 2px 2px 0;
}

.checkmark_kick {
  position: absolute;
  width: 6px;
  height: 4px;
  background-color: #fff;
  left: 10px;
  top: 18px;
  border-radius: 2px 0 0 2px;
}

/* Color picker
--------------------------------------------------- */

.modalArea {
  display: none;
  position: fixed;
  z-index: 10; /*サイトによってここの数値は調整 */
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.modalBg {
  width: 100%;
  height: 100%;
}

.colorDialogWrapper {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  height: 90%;
  width: 95%;
  padding: 0.5rem 0 0 0.5rem;
  border-radius: 6px;
  border: 1.5px solid rgba(88,88,88,1.0);
  background-color: white;
  box-sizing: border-box;
  box-shadow: 5px 5px 12px 2px rgba(205, 200, 200, 1);
}
.colorDialog {
  height: 100%;
  widht: 100%;
}
.fontcolor_square_container {
  height: 100%;
  width: 100%;
}
.fontcolor_square_container .fontcolor_square {
  height: 100px;
  width: 100px;
  margin: 0 0.5rem 0.5rem 0;
  cursor: pointer;
}
@media screen and (min-width: 769px) {
  .colorDialogWrapper {
    height: initial;
    width: 600px;
  }
}

/* Color sample
--------------------------------------------------- */

.title_color {
  color:rgba(64,64,64,1.0);
  text-shadow: 0 0 0.5px;
}
.title_color_01 {
  color:rgba(50,50,50,1.0);
  text-shadow: 0 0 0.5px;
}
.title_color_02 {
  color:rgba(210,50,50,1.0);
  text-shadow: 0 0 0.5px;
}
.title_color_03 {
  color:rgba(220,30,90,1.0);
  text-shadow: 0 0 0.5px;
}
.title_color_04 {
  color:rgba(140,32,128,1.0);
  text-shadow: 0 0 0.5px;
}
.title_color_05 {
  color:rgba(128,48,180,1.0);
  text-shadow: 0 0 0.5px;
}
.title_color_06 {
  color:rgba(48,100,128,1.0);
  text-shadow: 0 0 0.5px;
}
.title_color_07 {
  color:rgba(0,96,192,1.0);
  text-shadow: 0 0 0.5px;
}
.title_color_08 {
  color:rgba(32,160,96,1.0);
  text-shadow: 0 0 0.5px;
}
.title_color_09 {
  color:rgba(120,120,32,1.0);
  text-shadow: 0 0 0.5px;
}
.title_color_10 {
  color:rgba(220,128,48,1.0);
  text-shadow: 0 0 0.5px;
}
.title_color_11 {
  color:rgba(255,96,0,1.0);
  text-shadow: 0 0 0.5px;
}
.title_color_12 {
  color:rgba(240,96,128,1.0);
  text-shadow: 0 0 0.5px;
}
.title_color_13 {
  color:rgba(180,160,0,1.0);
  text-shadow: 0 0 0.5px;
}
.title_color_14 {
  color:rgba(240,210,0,1.0);
  text-shadow: 0 0 0.5px;
}
.title_color_15 {
  color:rgba(32,210,32,1.0);
  text-shadow: 0 0 0.5px;
}
.title_color_16 {
  color:rgba(0,152,220,1.0);
  text-shadow: 0 0 0.5px;
}
.title_color_17 {
  color:rgba(0,32,144,1.0);
  text-shadow: 0 0 0.5px;
}
.title_color_18 {
  color:rgba(0,68,16,1.0);
  text-shadow: 0 0 0.5px;
}
.title_color_19 {
  color:rgba(144,0,0,1.0);
  text-shadow: 0 0 0.5px;
}
.title_color_20 {
  color:rgba(112,112,112,1.0);
  text-shadow: 0 0 0.5px;
}

.fontcolor_square[data-colorid="0"] {
  background-color:rgba(64,64,64,1.0);
}
.fontcolor_square[data-colorid="1"] {
  background-color:rgba(50,50,50,1.0);
}
.fontcolor_square[data-colorid="2"] {
  background-color:rgba(210,50,50,1.0);
}
.fontcolor_square[data-colorid="3"] {
  background-color:rgba(220,30,90,1.0);
}
.fontcolor_square[data-colorid="4"] {
  background-color:rgba(140,32,128,1.0);
}
.fontcolor_square[data-colorid="5"] {
  background-color:rgba(128,48,180,1.0);
}
.fontcolor_square[data-colorid="6"] {
  background-color:rgba(48,100,128,1.0);
}
.fontcolor_square[data-colorid="7"] {
  background-color:rgba(0,96,192,1.0);
}
.fontcolor_square[data-colorid="8"] {
  background-color:rgba(32,160,96,1.0);
}
.fontcolor_square[data-colorid="9"] {
  background-color:rgba(120,120,32,1.0);
}
.fontcolor_square[data-colorid="10"] {
  background-color:rgba(220,128,48,1.0);
}
.fontcolor_square[data-colorid="11"] {
  background-color:rgba(255,96,0,1.0);
}
.fontcolor_square[data-colorid="12"] {
  background-color:rgba(240,96,128,1.0);
}
.fontcolor_square[data-colorid="13"] {
  background-color:rgba(180,160,0,1.0);
}
.fontcolor_square[data-colorid="14"] {
  background-color:rgba(240,210,0,1.0);
}
.fontcolor_square[data-colorid="15"] {
  background-color:rgba(32,210,32,1.0);
}
.fontcolor_square[data-colorid="16"] {
  background-color:rgba(0,152,220,1.0);
}
.fontcolor_square[data-colorid="17"] {
  background-color:rgba(0,32,144,1.0);
}
.fontcolor_square[data-colorid="18"] {
  background-color:rgba(0,68,16,1.0);
}
.fontcolor_square[data-colorid="19"] {
  background-color:rgba(144,0,0,1.0);
}
.fontcolor_square[data-colorid="20"] {
  background-color:rgba(112,112,112,1.0);
}
