:root{
	--page-bg: #060606;
	--header-bg: #1a1a1a;
	--nav-bg: #101010;
	--content-bg: #101010;
	--accent-color: #9F38DD;
	--light-accent: #fff;
	--text-color: #eee;
	--borders: rgba(255,255,255,0.2);

	--text-dark: #000;
	--log-bg: #050505;

	--nav-hover-bg: rgba(255,255,255,0.06);
	--nav-active-bg: rgba(255,255,255,0.12);
	--msg-bg: rgba(255,255,255,0.02);
	--msg-btn-hover-bg: rgba(255,255,255,0.1);

	--modal-backdrop-bg: rgba(0,0,0,0.8);
	--modal-shadow: 0 0 25px rgba(0,0,0,0.7);

	--max-width: 900px;
	--header-height: 40px;
	--nav-height: 70px;
	--sidebar-width: 250px;
	--sidebar-padding: 20px;
	--content-padding: 20px;

	--font-size: 17px;
	--header-text: 15px;
	--nav-text: 15px;
	--headings: 18px;
	--sub-headings: 13px;

	--header-title-size: 17px;
	--nav-link-size: 13px;
	--nav-icon-size: 22px;

	--log-title-size: 16px;
	--log-subtitle-size: 12px;
	--log-meta-size: 11px;

	--msg-font-size: 14px;
	--msg-role-size: 11px;
	--msg-meta-size: 11px;
	--msg-btn-size: 11px;

	--story-empty-size: 13px;
	--char-name-size: large;

	--modal-body-font-size: 13px;
	--css-modal-text-size: 12px;
}


/* GENERAL */

::selection{background:var(--accent-color);color:var(--page-bg);}
::-moz-selection{background:var(--accent-color);color:var(--page-bg);}

::-webkit-scrollbar-track{background:var(--header-bg);}
::-webkit-scrollbar{width:7px;background:transparent;}
::-webkit-scrollbar-thumb{background:var(--borders);border:2px solid var(--header-bg);border-radius:5px;}

*, *:before, *:after{box-sizing:border-box;}
body{margin:0;padding:;background:var(--page-bg);font-family:Open Sans,calibri,sans-serif;font-size:var(--font-size);line-height:1;color:var(--text-color);}

a{color:var(--accent-color);text-decoration:none;}
a:hover{color:var(--text-color);}

ul{list-style:circle;}
li{margin-bottom:15px;}

fieldset{border:1px solid var(--borders);border-radius:6px;padding:10px 12px;margin-bottom:12px;}
legend{font-size:var(--sub-headings);padding:0 4px;}
input,textarea,select{color:var(--text-color);background:var(--header-bg);border:1px solid var(--borders);padding:3px;border-radius:5px;font-family:inherit;font-size:inherit;}
input:focus,textarea:focus,select:focus{outline:1px solid var(--accent-color);}

h1,h2,h3,h4,h5,h6{margin:0;font-weight:normal;font-weight:bold;}
h2{font-size:var(--headings);}
h3{font-size:var(--sub-headings);border-bottom:1px solid var(--borders);margin:0 0 10px 0;padding:0 0 5px 0;}


/* CONTAINER */

article{max-width:var(--max-width);margin:0 auto;background:var(--content-bg);min-height:100vh;}

.icons{font-family:Material Symbols Outlined;}

#settings textarea{width:100%;height:100px;}
#settings p{margin:0 0 10px 0;}


/* HEADER */

header{background:var(--header-bg);height:var(--header-height);line-height:var(--header-height);padding:0 calc(var(--header-height) / 2);display:flex;justify-content:flex-start;align-items:center;font-size:var(--header-text);border-bottom:1px solid var(--borders);}
header h1{font-size:var(--header-title-size);margin:0 0 0 5px;}
header .login{margin:0 0 0 auto;}


/* NAV */

nav{border-bottom:1px solid var(--borders);display:flex;align-items:center;justify-content:center;font-size:var(--nav-text);text-align:center;height:var(--nav-height);line-height:1.4;}
nav a{display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--light-accent);margin:0 12px;text-decoration:none;font-size:var(--nav-link-size);opacity:0.7;padding:4px 6px;border-radius:6px;}

nav .icons{display:block;font-size:var(--nav-icon-size);margin:0 0 2px 0;}

nav a:hover{background:var(--nav-hover-bg);opacity:1;}
nav a.active{background:var(--nav-active-bg);opacity:1;}
nav a.active .icons, nav a:hover .icons{color:var(--accent-color);}


/* MAIN CONTENT */

main{height:calc(100vh - var(--nav-height) - var(--header-height));overflow:hidden;}
main section{height:100%;display:none;overflow:auto;padding:var(--content-padding);}
main #story-mode, main #chats{padding:0;}
main section.active{display:block;}

.cols{display:flex;height:100%;}
.side-list{width:var(--sidebar-width);padding:var(--sidebar-padding);height:100%;overflow:auto;}
.logs-content{padding:var(--content-padding);width:calc(100% - var(--sidebar-width));height:100%;overflow:hidden;display:flex;flex-direction:column;border-left:1px solid var(--borders);}


/* SIDEBAR LINKS */

.side-list .side-link{padding:10px;display:flex;align-items:center;color:var(--text-color);text-decoration:none;border-radius:5px;border:0;background:none;width:100%;text-align:left;cursor:pointer;}
.side-list .side-link .side-img{width:30px;height:30px;border-radius:100%;margin:0 8px 0 0;}
.side-list .side-link.active{background:var(--borders);}
.side-link span{font-size:x-small;opacity:0.5;}


/* NEW STORY BUTTON */

.new-story{width:100%;background:var(--accent-color);color:var(--light-accent);border:1px solid var(--borders);border-radius:10px;padding:6px 10px;font-size:13px;cursor:pointer;margin-bottom:12px;display:inline-flex;align-items:center;gap:4px;justify-content:center;}
.new-story .icons{font-size:16px;}
.new-story:hover{background:var(--light-accent);color:var(--text-dark);}

#new-story-form label{display:inline-block;width:130px;margin:6px 0;}
#new-story-form input[type="text"]{width:calc(100% - 140px);}
#new-story-form textarea{width:100%;resize:vertical;}
#new-story-form input[type="submit"]{background:var(--accent-color);color:var(--light-accent);border:1px solid var(--borders);border-radius:10px;padding:6px 14px;font-size:13px;cursor:pointer;}
#new-story-form input[type="submit"]:hover{background:var(--light-accent);color:var(--text-dark);}


/* CHAT / STORY LOG AREA */

.log-header{margin-bottom:10px;border-bottom:1px solid var(--borders);padding-bottom:6px;display:flex;justify-content:space-between;align-items:center;gap:10px;}
.log-header-main h2{font-size:var(--log-title-size);margin:0;}
.log-header-main span{font-size:var(--log-subtitle-size);opacity:0.7;}
.log-header-meta{font-size:var(--log-meta-size);opacity:0.7;text-align:right;}

.chat-log{flex:1;overflow:auto;border:1px solid var(--borders);border-radius:8px;padding:10px;background:var(--log-bg);margin-bottom:10px;}

.msg{margin-bottom:8px;padding:8px 10px;border-radius:6px;font-size:var(--msg-font-size);background:var(--header-bg);position:relative;}
.msg:last-child{margin-bottom:0;}
.msg-role{font-size:var(--msg-role-size);opacity:0.7;margin-bottom:3px;text-transform:uppercase;letter-spacing:0.04em;}
.msg-user{border-left:3px solid var(--accent-color);}
.msg-ai{border-left:3px solid var(--light-accent);}
.msg-system{border-left:3px solid var(--borders);opacity:0.9;font-size:12px;}
.msg-body{white-space:pre-wrap;}


/* CHAT / STORY LOG MESSAGES */

.msg-log{max-height:calc(100% - 80px);overflow:auto;}
.msg-body{white-space:pre-wrap;}

.msg{padding:10px 12px;margin-bottom:8px;border-radius:6px;border:1px solid var(--borders);background:var(--msg-bg);}
.msg-user{border-color:var(--accent-color);}
.msg-ai{border-color:var(--borders);}

.msg-meta{font-size:var(--msg-meta-size);opacity:0.7;margin-bottom:4px;}
.msg-controls{margin-top:6px;display:flex;flex-wrap:wrap;gap:6px;}

.msg-btn{border:1px solid var(--borders);background:transparent;color:var(--light-accent);border-radius:999px;padding:2px 8px;font-size:var(--msg-btn-size);cursor:pointer;}
.msg-btn:hover{background:var(--msg-btn-hover-bg);}

.msg-btn-primary{background:var(--accent-color);border-color:var(--accent-color);}
.msg-btn-primary:hover{background:var(--light-accent);color:var(--text-dark);}
.msg-btn-secondary{}


.chat-input{margin-top:0;border-top:1px solid var(--borders);padding-top:8px;display:flex;flex-direction:column;gap:6px;}
.chat-input label{font-size:12px;opacity:0.8;}
.chat-input textarea{width:100%;resize:vertical;min-height:60px;}
.chat-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px;}
.chat-actions button{background:var(--accent-color);color:var(--light-accent);border:1px solid var(--borders);border-radius:999px;padding:6px 14px;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:4px;}
.chat-actions button:hover{background:var(--light-accent);color:var(--text-dark);}
.chat-actions .icons{font-size:16px;}


/* MODALS */

.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:999;}
.modal.active{display:flex;}

.modal-backdrop{position:absolute;inset:0;background:var(--modal-backdrop-bg);}

.modal-dialog{position:relative;z-index:1;background:var(--header-bg);border:1px solid var(--borders);border-radius:8px;max-width:800px;width:90%;display:flex;flex-direction:column;box-shadow:var(--modal-shadow);}

.modal-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--borders);}
.modal-header h2{font-size:var(--headings);margin:0;}

.modal-close{border:none;background:transparent;color:var(--text-color);cursor:pointer;padding:2px;border-radius:4px;}
.modal-close:hover{background:var(--msg-btn-hover-bg);}
.modal-body{padding:20px;max-height:80vh;overflow:auto;font-size:var(--modal-body-font-size);}

#backstory, #plotline{width:100%;height:300px;}


/* CHARACTERS */

.char-list{display:flex;flex-wrap:wrap;justify-content:center;text-align:center;}
.char{width:170px;border:1px solid var(--borders);padding:15px;border-radius:5px;margin:10px;}
.char-pfp{width:100px;height:100px;border-radius:100%;background:var(--header-bg);object-fit:cover;}
.char h3{font-size:var(--char-name-size);margin:10px 0;}
.bio-link{background:var(--accent-color);color:var(--light-accent);padding:2px 6px;border-radius:5px;border:1px solid var(--borders);}

.char-add-btn{background:var(--accent-color);color:var(--light-accent);border:1px solid var(--borders);border-radius:10px;padding:6px 14px;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:4px;}
.char-add-btn .icons{font-size:16px;}
.char-add-btn:hover{background:var(--light-accent);color:var(--text-dark);}

#new-character{}
#new-character h3{}
#new-character label:not(#new-character .role-group label){display:inline-block;width:140px;}
#new-character input[type="text"]{}
#new-character input[type="submit"]{background:var(--accent-color);color:var(--light-accent);border:1px solid var(--borders);border-radius:10px;padding:6px 14px;font-size:13px;cursor:pointer;display:inline-block;margin:10px auto 0 auto;}
#new-character input[type="file"]{}

#new-character .appearance-group label{display:block;width:100%;}
#new-character .appearance-group input[type="text"]{display:block;}


/* CUSTOMIZATION */

#customize h2{text-align:center;margin:0 0 10px 0;padding:0 0 5px 0;}
#customize label{display:inline-block;width:170px;}
#customize label, #customize input{margin:0 0 8px 0;}
#customize input{}
#customize .custom-css{width:100%;height:300px;}

.css-modal-body{padding:10px 12px 12px;font-size:var(--modal-body-font-size);}
#css-modal-text{width:100%;height:55vh;resize:vertical;background:var(--content-bg);font-family:Consolas,monaco,monospace;font-size:var(--css-modal-text-size);line-height:1.4;}


/* STORIES TAB */

#stories{padding:0;}
#stories .cols{flex-wrap:wrap;}
#stories p{margin:0;}
.story-head{width:100%;border-bottom:1px solid var(--borders);margin:0;padding:var(--content-padding);}
.story-empty{opacity:0.6;font-size:var(--story-empty-size);}
.stories-content{padding:var(--content-padding);width:calc(100% - var(--sidebar-width));min-height:100%;display:flex;flex-direction:column;border-left:1px solid var(--borders);}

#story-config-form label{display:block;margin:6px 0 2px;}
#story-config-form textarea{width:100%;resize:vertical;}
#story-config-form .half-row{display:flex;gap:10px;}
#story-config-form .half-row > div{flex:1;}


/* DYNAMIC BACKGROUND */

#bg-layer{position:fixed;inset:0;z-index:-1;background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed;opacity:0;transition:opacity 0.4s ease;}

body.has-story-bg{}