body
{
	text-align:center;
	--bg-color: white;
	--text-color: black;
	--nav-text-color: white;

	--nav-color: #833873;
	--md-sys-color-primary: #6a0032;
	--btn-color-hover: #a14aa1;
	--btn-color: var(--md-sys-color-primary);

	--nav-color-hover: #bf4040;

	--sidenav-icon-color: rgba(0,0,0,0.54);
	--card-color: #deebff;
	--collection-item-color:#fff;
	--dropdown-color: #fff;
	--dropdown-text-color:#7e26a6;
	--dropdown-text-dark: darkred;
	--dropdown-hover-color:#eee;
	--settings-row-border-color: rgba(0, 0, 0, 0.12);
	--colored-dialogue: brightness(0.6);
	
	background-color: var(--bg-color);
	color: var(--text-color);
}

@media (prefers-color-scheme: dark) {

	body{
		--bg-color: #333333;
		--text-color: white;
		--md-sys-color-on-primary: white;
		--nav-color:#1a237e;
		--nav-color-hover:#3465a4;
		--sidenav-icon-color: rgba(255,255,255,0.54);
		--btn-color: #0e154f;
		--card-color: #455a64;
		--dropdown-color: #455a64;
		--collection-item-color:#2b2b2b;
		--dropdown-text-color: white;
		--dropdown-text-dark: lightpink;
		--dropdown-hover-color: black;
		
		--settings-row-border-color: rgba(255, 255, 255, 0.5);
		--colored-dialogue: brightness(1.0);
	}

	body.black-theme{
		--bg-color: black;
		--text-color: white;
		--nav-color: #212121;
		--sidenav-icon-color: rgba(255,255,255,0.54);
		--btn-color: #455a64;
		--card-color: #2e3436;
		--collection-item-color: black;
		--dropdown-text-color: white;
		--dropdown-text-dark: lightpink;
		--dropdown-hover-color: black;
		
		--settings-row-border-color: rgba(255, 255, 255, 0.8);
		--colored-dialogue: brightness(1.0);
	}
}

nav {
	background-color: var(--nav-color);
}
.sidenav {
	text-align: left;
	background-color: var(--bg-color);
	color:var(--text-color);
}
.sidenav li > a {
	color:var(--text-color);
	line-height: 1;
}
.sidenav li > a > i.material-icons {
	color:var(--sidenav-icon-color)
}
.sidenav li > a > span {
	/*height:48px;*/
	vertical-align: middle;
	display:table-cell;
}
/* For sidenav */
.divider-with-text {
	overflow: hidden;
	text-align: center;
	line-height:24px !important;
}

.divider-with-text::before,
.divider-with-text::after {
	background-color: var(--text-color);
	content: "";
	display: inline-block;
	height: 1px;
	position: relative;
	vertical-align: middle;
	width: 50%;
}

.divider-with-text::before {
right: 0.5em;
margin-left: -50%;
}

.divider-with-text::after {
left: 0.5em;
margin-right: -50%;
}
  

textarea{
	color:var(--text-color);
}
input{
	color:var(--text-color);
}
label {
	color: var(--text-color);
}
h2 {
	margin: 1.424rem 0 1.424rem 0;
}

.textarea-wrapper{
	/*border:1px solid red;*/
	position:relative;
	height:500px;
	width:700px;
	margin:15px auto
}
/*.textarea-wrapper::before {
	content:"wrapper";
	text-transform: uppercase;
	left:0px;
	position:absolute;
	top:-18px;
	font-size:16px;
	color:red;
}*/

/*table, th, td {
   border: 1px solid #222222;
   border-collapse: collapse;
}
th {
	background-color: purple;
}*/

.header-desktop{
	display: inline-block;
}
.header-desktop-shorter{
	display: none;
}
.header-mobile{
	display: none;
}

.chapterTitles-mobile{
	display: none;
}

#mobileWarning {
	display:none;
}

.navbarButton > i {
	padding-right: 5px;
}

@media screen and (max-width: 1280px) {
    .header-desktop{
       display:none;
    }
    
    .header-desktop-shorter{
       display:inline-block;
    }
    
    .chapterTitles-desktop{
		display: none;
	}
	.chapterTitles-mobile{
		display: block;
	}
    
    .navbarButton > i{
    	padding-right: 0;
    }
    
    .modal {
		--modal-border-radius: 0;
    	width:100%;
    	max-height:100%;
    	height:100%;
    	top:0 !important;
    }
    .modal.modal-fixed-footer{
    	height:100%;
    }



	#mobileWarning {
		display:inline;
	}
	#TDollStuffInner {
		display:none;
	}

}

@media screen and (max-width: 600px) {
    .header-desktop{
       display:none;
    }
    .header-desktop-shorter{
       display:none;
    }
    
    .header-mobile{
       display:inline-block;
    }

	/* .navbarButton > i {
		margin-right: 5px;
	} */
}

.btn, .btn:focus {
	background-color: var(--btn-color);
}
.btn:hover {
	background-color: var(--btn-color-hover);
}
.btn {
	color: white;
	text-wrap: wrap;
	height: auto;
	min-height: var(--btn-height);
	padding-bottom: 5px;
	padding-top: 5px;
}

/*[type="checkbox"].filled-in:checked + span:not(.lever)::after {
	border: 2px solid var(--btn-color);
	background-color: var(--btn-color);
}
[type="radio"]:checked + span::after, [type="radio"].with-gap:checked + span::after {
	background-color: var(--btn-color);
}
[type="radio"]:checked + span::after, [type="radio"].with-gap:checked + span::before, [type="radio"].with-gap:checked + span::after {
	border: 2px solid var(--btn-color);
}
.progress .determinate {
	background-color: var(--btn-color);
}*/


.card {
	background-color: var(--card-color);
}
.modal {
	background-color: var(--bg-color);
	/* sadly animating 'top' breaks the modal showing */
	transition: width 0.2s ease-out, height 0.2s ease-out;
}
.collection .collection-item{
	background-color: var(--collection-item-color)
}
/*Remove the red circle padding since I don't use it */
.collection .collection-item.avatar {
	padding-left: 10px;
}

.dropdown-content{
	background-color: var(--dropdown-color);
}
.dropdown-content li > a {
	color: var(--dropdown-text-color);
}
.dropdown-content li.dark-stage > a {
	color: var(--dropdown-text-dark)
}

.dropdown-content li:hover, .dropdown-content li.active {
  background-color: var(--dropdown-hover-color);
}

.collapsible-header {
	background-color: var(--collection-item-color);
}

.pagination{
	max-width:700px;
	margin-left:auto;
	margin-right:auto;
}
.pagination li a {
	color: var(--text-color);
}
.pagination li.active {
	background-color: var(--nav-color);
}
.pagination li.active:hover{
	background-color:var(--nav-color-hover);
}
.pagination li {
	margin-left: 5px;
	margin-top: 5px;
}

/*Something I actually wrote myself*/
.material-settings-table {
	padding: 0px;
}
.material-settings-table td {
	padding: 5px 0 5px 0;
}
.material-settings-table p {
	margin: 0px;
}
.material-settings-table tr {
	border-bottom-color: var(--settings-row-border-color);
}

.material-settings-table .title {
	font-weight: bold;
	font-size:120%
}
.modal .modal-footer {
	background-color: rgba(128,128,128,0.3);
}
.modal .modal-footer > a {
	color: var(--text-color);
}


@media only screen and (min-width: 993px) {
	#toast-container {
		top: unset;
		bottom: 10%;
		right: 20%;
		/*max-width: unset;*/
	}
}

/*#head, #foot {
	height: 6%;
	min-height: 25px;
	width: 100%;
	background-color: #151515;
	overflow: hidden;
}

#head a {
  float: left;
  color: #f2f2f2;
  text-align: center;
  padding: 14px 16px;
  text-decoration: none;
  font-size: 17px;
}


#head a:hover {
  background-color: #ddd;
  color: black;
}

#head a.active {
  background-color: #4CAF50;
  color: white;
}*/

.tabs {
    display:-webkit-flex;
    display: -ms-flexbox;
    display: flex
}

.tabs .tab a:focus, .tabs .tab a:focus.active {
	background-color: unset;
}


.flex-container {
  display: flex;
  flex-wrap: wrap;
  /*background-color: DodgerBlue;*/
  justify-content: center;
  align-items: center;
}

.flex-container > div {
  /*background-color: #f1f1f1;*/ /*I don't remember why I put this here. It makes the buttons square though. */
  margin: 5px;
  /*padding: 20px;
  font-size: 30px;*/
}

/*tr:nth-child(odd) {
    background-color: #000000CC;
}
tr:nth-child(even) {
    background-color: #111111CC;
}*/



#verySimpleText{
	text-align: left;
	font-family: 'Noto Sans JP', sans-serif;
	margin-left: 10px;
	margin-right: 10px;
}
.coloredDialogue{
	filter: var(--colored-dialogue);
}

/*
To make everything nice and centered on desktop.
It's wider than GFL because PNC is ultrawide resolution instead of 16:9
*/
@media screen and (min-width:791px) {

	#verySimpleText{
		margin-left: 0px;
		margin-right: 0px;
		width: 790px; 
		margin: 0 auto;
	}
}

/*.container {
  position: relative;
  text-align: center;
  color: white;
}

.charName {
  font-family: 'Noto Sans KR', sans-serif;
  position: absolute;
  top: 5px;
  left: 16px;
  font-size: 2vw;
}

.absText {
      font-family: 'Noto Sans KR', sans-serif;
  position: absolute;
  top: 45px;
  left: 16px;
  font-size: 2.2vw;
}*/


/*.speakerName{
	font-weight: bold;
}*/


.fgEffect{
	position: absolute; width:100%; height:100%;bottom: 0;
}

.snow{
	background-image:
        url(snow1.png),
           url(snow2.png),
           url(snow3.png);
	animation: snow 30s linear infinite;
}

@keyframes snow {
    0% {background-position: 0px 0px, 0px 0px, 0px 0px;}
    100% {background-position: 500px 1000px, 400px 400px, 300px 300px}
}

.raindrop{
	/* This lags my computer */
	/*mix-blend-mode: overlay;*/
	position: absolute;
	animation: rain var(--speed) linear infinite;
	/*left: var(--x);
	top: var(--y);*/
}
@keyframes rain {
	0% {
		transform: translateY(-20%);
	}
	100% {
		transform: translateY(100%);
	}
}


.storyText {
	margin-top: 0.5ex;
	margin-bottom: 0.5ex;
	overflow-wrap: break-word;
}

.storyText.centered {
	text-align: center;
}

.storyText.speakerName {
	/*margin-top: 0;*/
	font-weight: bold;
}

.tooltip {
	align-items: normal;
	background-color: rgba(0,0,0,0);
	border-color: #039be5;
	border-style: none;
	box-sizing: content-box;
	color: #039be5; 
	filter: var(--colored-dialogue);
	/* cursor: pointer; */
	display: inline;
	font: inherit;
	height: auto;
	padding: 0;
	perspective-origin: 0 0;
	text-align: start;
	/* text-decoration: underline; */
	transform-origin: 0 0;
	width: auto;
	outline: 1 solid red;
	appearance: none;
	-moz-appearance: none;
	-webkit-logical-height: 1em;
	-webkit-logical-width: auto;
  }
  
  @supports (-moz-appearance:none) { 
	.tooltip::-moz-focus-inner {
	  border: none;
	  padding: 0;
	}
  
	.tooltip:focus {
	  outline-style: dotted;
	  outline-width: 1px;
	}
  }

/*
Blatantly stolen from gfl.zzzzz.kr 
I have no idea how it works
*/
.storyImg{
	position:relative;
	overflow:hidden; /*Keep portraits within div */
	width:100%;
	margin-top:1.5rem;
}
.storyImg .bg {
	width: 100%;
	position: relative;
	display: block;
	aspect-ratio: 2/1; /*THANK GOD FOR MODERN CSS*/
}
.storyImg .bg > img {
	max-width: 100%;
	position: absolute;
	left: 0;
	top: 0;
}

.storyImg .filter {
	width: 100%;
	position: relative;
	display: block;
	opacity: '0%';
}

.storydoll{
	/* width:65%; */
	height: 120%;
	position: absolute;
	bottom: -30%;
	z-index: 5; /*higher number means it's drawn in front */
}

.storydoll.second{
	right:42%
}
.storydoll.third{
	/*left:15%;*/ /*Margin of 15%, which also creates a right margin of 15%, which adds up the remaining 30% in 'width' in storyImg class */
	left: calc((100% - 60%)/2);
}
.storydoll.fourth{
	left:42%
}

.storydoll.dim{
	filter: brightness(50%);
	z-index:4;
}
.storydoll.mask {
	mask-position: center;
	mask-size: 100%; /* I don't know why 100% works but it does */
	-webkit-mask-size: 100%;
	filter: brightness(300%) opacity(75%);
}
/*This is the faces over the characters */
.storydoll > :nth-child(2) {
	position:absolute;
}
.storydoll > img.portrait {
	height: 100%;
}

.maskcontainer{
	z-index:5;
}
.maskcontainer.second{
	left:15%;
}
.maskcontainer.third{
	left:35%; /*This is a guess, I don't know how it works */
}
.maskcontainer.fourth{
	left:55%
}
/*Should probably fix later */
.maskcontainer.dim{
	z-index:4;
}
.maskcontainer > div > img.dim{
	filter: brightness(50%);
}

.msgbox {
	border: 1px black solid;
	/* border-radius: 5px; */
	/*padding-left: 5px;
	padding-right: 5px;*/
	display:table;
	width:100%;
	overflow: hidden;
	margin-top: 2.5px;
	margin-bottom: 2.5px;
	background: var(--card-color);
}
/* .msgbox > * {
	display: table-cell;
} */
/* .msgbox > span {
	vertical-align: top;
	width:100%;
	padding: 5px;
} */

.msgbox > img {
	display:block;
	float:left;
	width: 128px;
	margin-right: 10px;
}
.msgbox > div > .speakerName {
	display: block;
}

#SearchResults {
	cursor: pointer;
	display: block;
	text-align: left;
}
/*lol */
.collection-item.waves-effect {
	display: inherit;
}

.grid-container {
	display: grid;
	grid-template-areas:
		'menu main';
	grid-template-columns:25% auto;
	grid-gap:10px;
	padding: 0px;

}

.card.indented p {
	display:list-item;
	padding-inline-start: 1ch;
	list-style-type: ">";
	margin-left: 15px;
}

.card-image {
	max-width:100%;
	background-color: rgba(0, 0, 0, 0.5);
}

.card-image > .card-title {
    color: white !important;
	/* text-shadow: #000 1px 0 10px; */
	z-index: 2;
    text-shadow: -1px -1px 0 black,  
                 1px -1px 0 black,  
                -1px  1px 0 black,  
                 1px  1px 0 black;
}

.loading {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.5);
	display: flex;
	justify-content: center;
	align-items: center;
	z-index: 9999;
}

#loadingBar.loading {
	display: flex;
	flex-direction: column; 
	align-items: center;
	justify-content: center;
  }
  
  #loadingBar > div {
	width: 100%; 
	text-align: center;
  }
  
  .progress {
	margin-top: 10px;
  }

  .eosIco {
	display: block; 
	width: 256px; 
	height: auto; 
	margin: auto;
  }

  .ch-desc {
	font-size:1.5rem;
	line-height:100%;
	margin:1rem auto 0 auto;
	overflow-wrap: break-word;
	max-width: 800px;
  }