* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    width: 100%;
    height: 100vh;
    margin: 0;
    padding: 0;
    /** Dev-only styles **/
    background-color: var(--background-color);
    color: var(--primary-color);
    /** End: Dev-only styles **/
    /** End: Dev-only styles **/
    font-family: Fira Mono, DejaVu Sans Mono, Menlo, Consolas, Liberation Mono, Monaco, Lucida Console, monospace;
    overflow: hidden;
}

button:enabled {
    cursor: pointer;
}

button:disabled {
    cursor: not-allowed;
}

/* https://stackoverflow.com/questions/6370690/media-queries-how-to-target-desktop-tablet-and-mobile */
/* !!! In practice, many designers convert pixels to ems, largely because ems afford better zooming. !! */
/* https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_media_queries/Using_media_queries */
/*@media (min-width:320px)  {*/
/*    !* smartphones, portrait iPhone, portrait 480x320 phones (Android) *!*/
/*}*/
/*@media (max-width:1370px)  { !* my ipad is 1366 x 1024 *!*/

/*}*/

/*@media (max-width: 602px) {*/
/*    #cwm-lo-right-widget {*/
/*        display: block;*/
/*        position: absolute;*/
/*        bottom: 0;*/
/*        left: 0;*/
/*        height: 40%;*/
/*        !** Can this be overridden without !important **!*/
/*        width: 100% !important;*/
/*    }*/
/*    #cwm-lo-left-widget {*/
/*        !*height: 60%;*!*/
/*    }*/
/*    #cwm-lo-left-right-drag {*/
/*        display: none;*/
/*    }*/
/*    .cwm-dashboard-block-buttons button {*/
/*        width: 98%;*/
/*    }*/
/*}*/

/*@media (max-width: 400px) {*/
/*    .cwm-dashboard > section {*/
/*        padding: 0;*/
/*        margin: 0;*/
/*        border: none;*/
/*        height: 100%;*/
/*    }*/
/*    .cwm-dashboard-block {*/
/*        width: 100%;*/
/*        border: none;*/
/*    }*/
/*    .cwm-dashboard-block h2, p {*/
/*        display: none;*/
/*    }*/
/*    .cwm-dashboard-block-buttons button {*/
/*        width: 98%;*/
/*    }*/
/*    !*.cwm-hide-on-small {*!*/
/*    !*    display: none;*!*/
/*    !*}*!*/
/*}*/
/*@media (max-width: 460px) {*/
/*    #cwm-lo-right-widget {*/
/*    }*/
/*}*/
/*@media (min-width:600px)  { !* portrait tablets, portrait iPad, e-readers (Nook/Kindle), landscape 800x480 phones (Android) *! }*/
/*@media (min-width:801px)  { !* tablet, landscape iPad, lo-res laptops ands desktops *! }*/
/*@media (min-width:1025px) { !* big landscape tablets, laptops, and desktops *! }*/
/*@media (min-width:1281px) {*/
/* hi-res laptops and desktops */
/*@media (min-width:900px) {*/
/*}*/

/*@font-face {*/
/*    !*font-family: 'Custom Emoji';*!*/
/*    font-size: xx-large;*/
/*    !*src: url('path/to/emoji-font.woff2') format('woff2');*!*/
/*    unicode-range: U+1F300-1F5FF; !* Unicode range for emojis *!*/
/*}*/


#init-error {
    width: 75%;
    color: var(--primary-color);
    font-size: x-large;
    text-align: center;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
}

#init-error > * {
    flex: 0 0 100%;
    flex-direction: row;
}

/**Container displayed by the router when a module error goes unhandled**/
#cwm-logged-out-container, #cwm-error-container {
    width: auto;
    margin: 0;
    padding: 5em;
}
#cwm-error-container ul {
    list-style-type: none;
    font-family: monospace;
    text-indent: 2em;
}
#cwm-error-container pre {
    font-family: monospace;
    font-size: larger;
}
#cwm-error-container blockquote {
    font-size: larger;
    width: 60%;
    text-align: center;
}
#cwm-error-details {
    border: var(--border-two);
    padding: 1em;
}

#cwm-error-container button {
    background-color: var(--secondary-color);
    color: var(--primary-color);
    border: var(--border-one);
    padding: 10px;
    font-size: x-large;
    cursor: pointer;
}
#cwm-error-container button:hover {
    background-color: var(--primary-color);
    color: var(--secondary-color);
}

#cwm-logged-out-inner {
    display: flex;
    /*width: 75%;*/
    border: var(--border-one);
    background-color: var(--secondary-color);
    clear: bottom;
    padding: 20px;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    flex-direction: column;
}
#cwm-logged-out-inner > * {
    margin: 1em;
}
#cwm-logged-out-inner pre {
    font-family: monospace;
    flex-wrap: wrap;
}
#cwm-app-splash {
    display: flex;
    box-sizing: border-box;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 50%;
    left: 50%;
    height: 50vh;
    transform: translate(-50%, -50%);
    /*background-size: contain;*/
    /*background-image: url('../img/brian-phone.svg');*/
    /*background-repeat: no-repeat;*/
    /*background-position: center;*/
}
#cwm-app-splash-content {
    border: 2px solid #ff00ff;
    /*background-color: #026;*/
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background-color: rgba(200, 200, 200, 0.8);
    color: #000;
    height: 100%;
    width: 100%;
    box-sizing: border-box;
    padding: 2em;
}

#cwm-app-splash-content > * {
    margin: .5em;
    text-align: center;
}

#cwm-app-splash-content a {
    border: 1px solid #ff00ff;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1em;
    font-size: xx-large;
    text-decoration: none;
    color: #000;
    text-align: center;
    box-sizing: border-box;
}
#cwm-app-splash-content a:hover, #cwm-splash-content {
    box-shadow: magenta 0 0 20px;
}
.splash-logged-out {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    height: 30rem;
}

#cwm-app-splash-login {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    height: 30rem;
    background-color: #026;
    color: #ff00ff;
    font-family: "Apple Chancery", Times, serif;
}

/**** Layout Objects 'lo' *****/
/** These objects are not for any styling other than
 ** layout work.
 */
#cwm-layout-table {
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    border-collapse: collapse;
}
td, tr {
    vertical-align: top;
    padding: 0;
    margin: 0;
}

/***************************************/
/*************** Layout  ***************/
/***************************************/
#cwm-lo-top-nav {
    /*height: 40px;*/
    height: 40px;
    margin: 0;
    padding: 0;
}
#cwm-lo-top-widget {
    box-sizing: border-box;
    height: 80px;
}
#cwm-lo-main {
    display: flex;
    flex-direction: row;
}
#cwm-lo-right-widget {
    width: var(--right-widget-width);
    height: calc(100vh - 90px); /* hacky - how does this work with 100vh? issue: controls fall off screen*/
}
#cwm-lo-left-widget {
    overflow-y: scroll;
    overflow-x: hidden;
    height: calc(100vh - 120px);
    width: 100%;
    padding: 0;
}

/*!* This will change the scrollbar track *!*/
/*#cwm-lo-left-widget-content::-webkit-scrollbar {*/
/*    width: 10px;*/
/*    background-color: var(--accent-color); !* Change this to your desired color *!*/
/*}*/

/*!* This will change the scrollbar thumb (the moving part) *!*/
/*#cwm-lo-left-widget-content::-webkit-scrollbar-thumb {*/
/*    background-color: var(--primary-color); !* Change this to your desired color *!*/
/*    border-radius: 10px;*/
/*}*/

/*!* This will change the scrollbar thumb when it's hovered *!*/
/*#cwm-lo-left-widget-content::-webkit-scrollbar-thumb:hover {*/
/*    background-color: var(--primary-color); !* Change this to your desired color *!*/
/*}*/

#cwm-lo-left-right-drag {
    width: 4px;
    background-color: var(--accent-color);
    /*cursor: col-resize;*/
}
.cwm-lo-hidden  {
    display: none;
}
#cwm-lo-right-message {
    font-size: larger;
    margin: 25px;
    line-height: 1.8em;
    text-align: center;
}
#cwm-lo-right-message > a {
    display: block;
    color: var(--primary-color);
    text-decoration: none;
    border: var(--border-two);
    padding: 10px;
    margin-top: 20px;
}
#cwm-lo-right-message > a:hover {
    color: var(--secondary-color);
    background-color: var(--primary-color);
}

#cwm-overlay {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 9000;
    background-color: #000;
    width: 100%;
    height: 100vh;
    opacity: 0.6;
}
.cwm-loading-msg {
    position: absolute;
    top: 25%;
    width: 60%;
    left: 25%;
    z-index: 9001;
    background-color: var(--secondary-color);
    color: var(--primary-color);
    min-width: 200px;
    height: 100px;
    margin: -50px 0 0 -100px;
    padding: 10px;
    text-align: center;
    border: var(--border-one);
    border-radius: var(--border-radius-md);
    font-size: x-large;
    cursor: pointer;

}
/**********************************************************/
/** First level  children that JS creates within lo divs **/
/**********************************************************/

/*.cwm-right-hand-container > button {*/
/*    margin: 10px;*/
/*    padding: 10px;*/
/*    border: var(--border-one);*/
/*    background-color: var(--secondary-color);*/
/*    color: var(--primary-color);*/
/*    font-size: large;*/
/*    cursor: pointer;*/
/*}*/
/*.cwm-right-hand-container > button:hover {*/
/*    background-color: var(--primary-color);*/
/*    color: var(--secondary-color);*/
/*}*/

/*.cwm-left-hand-container { !** Every outer container added to the right-hand side **!*/
/*    width: 100%;*/
/*    overflow-y: scroll;*/
/*    margin: 0;*/
/*}*/

/***********************************************************/
/*************** Top-Nav: Default cwm-nav.js ***************/
/* ul > li > a */
#cwm-nav-brand {

}
#cwm-nav-parent { /*ul*/
    display: inline-block;
    width: 100%;
    background-color: var(--secondary-color);
    height: 100%;
    list-style-type: none;
    list-style-position: inside;
    margin: 0;
    padding: 0;
}
.cwm-nav-li { /*li containing the a link aka 'cwm-nav-link' */
    box-sizing: border-box;
    display: inline-block;
    height: 40px;
    min-width: 100px;
    padding: 0;
    margin: 0;
    border-right: 1px solid var(--accent-color);
}
.cwm-nav-li:last-child {
    border-right: none;
}
.cwm-nav-link {
    box-sizing: border-box;
    /*border: 4px solid var(--background-color);*/
    border-bottom: 4px solid var(--secondary-color);
    display: block;
    padding-top: 0;
    padding-bottom: 0;
    padding-left: 20px;
    padding-right: 20px;
    height: 100%;
    line-height: 40px;
    text-decoration: none;
    color: var(--primary-color);
}
.cwm-nav-link:hover {
    background-color: var(--primary-color);
    color: var(--secondary-color);
    cursor: pointer;
    /*border: 4px solid var(--secondary-color);*/
    text-decoration: underline;
    /*text-decoration-style: dotted;*/
    text-decoration-thickness: 2px;
    /*text-decoration-color: var(--accent-color);*/
}

/***************************************/
/*************** Boards  ***************/
.cwm-board {
    height: 100%;
    /** Relative pos required for drawer **/
    position: relative;
}

#cwm-board-list-outer {
    width: 100%;
    padding: 15px;
    margin: 0;
}
#cwm-board-list { /*ul*/
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    /*align-items: stretch;*/
    padding: 0;
    margin: 0;
    text-indent: 0;
}

.cwm-board-list-item-lnk:hover, .cwm-board-list-item-lnk:hover > a {
    background-color: var(--primary-color);
    color: var(--accent-color);
}

/** Method B: Flexbox **/
.cwm-board-section {
    border: var(--border-two);
    margin-left: 8px;
    margin-right: 8px;
    /** May 26 - this may cause another issue but was making the area scrollable when shouldn't be**/
    margin-bottom: 8px;
    /*margin-top: 8px;*/
    /*justify-content: stretch;*/
    /*align-items: stretch;*/
}
.cwm-board-section > h2 {
    color: var(--primary-color);
    text-align: center;
    margin-top: 0;
}

/** Button Div with buttons in a single section **/
.cwm-board-button-group { /* container with obj to flex */
    display: flex;
    flex-wrap: wrap;
    /*justify-content: stretch;*/
    justify-content: space-around;
    /*align-items: stretch;*/
    align-items: center;
    box-sizing: border-box;
}
/** Div containing button and future edit controls **/
.cwm-board-button-wrapper { /* object to show as flex (the button+) */
    box-sizing: border-box;
    flex: 1 1 12%; /** 20% = 4 per row **/
    min-width: 12em;
    margin: 5px;
    justify-content: stretch;
    align-items: stretch;
    /*z-index: 1;*/
}
.cwm-board-button-control-wrapper {
    max-width: 25%;
}
.cwm-board-button {
    cursor: pointer;
}
.cwm-board-button, .cwm-board-button-edit-div {
    box-sizing: border-box;
    min-height: 100px;
    width: 100%;
    max-width: 100%;
    height: 100%;
    background-color: var(--background-color);
    color: var(--primary-color);
    border: var(--border-one);
    border-radius: var(--border-radius-md);
    font-size: x-large;
}

.cwm-board-control-button {
    box-sizing: border-box;
    min-height: 100px;
    /*width: 25%;*/
    height: 100%;
    background-color: var(--background-color);
    color: var(--primary-color);
    border: var(--border-one);
    border-radius: var(--border-radius-md);
    font-size: x-large;
}

.cwm-board-button:hover {
    background-color: var(--secondary-color);
    box-shadow: var(--standard-shadow);
}
.cwm-board-button-edit-div {
    display: flex;
    box-sizing: border-box;
    padding: 0;
}
.cwm-board-button-edit-div textarea {
    width: 100%;
    box-sizing: border-box;
    border: none;
    margin: .5em;
    padding: .5em;
    font-size: large;
    background-color: var(--background-color);
    color: var(--primary-color);
    border-bottom: var(--border-one);
    resize: none;
}


/********************************************************/
/*************** CWM Board - Side Drawer  ***************/
.cwm-board-modal-side-drawer {
    z-index: 2000;
    /*background-color: var(--accent-color);*/
    height: 98%;
    position: absolute;
    top: 0;
    left: 0;
    /*box-shadow: 0 0 5px 5px var(--secondary-color);*/
    /*box-shadow: 5px 5px 5px 0 var(--background-color);*/
    flex-direction: column;
    /*flex-wrap: wrap;*/
    /*flex-grow: 1;*/
    /*justify-content: space-around;*/
    min-width: 30%;
    box-sizing: border-box;
    background-color: var(--background-color);
    border: var(--border-one);
}
.cwm-board-modal-side-drawer.closed {
    box-sizing: border-box;
    height: auto;
}

.cwm-board-modal-side-drawer.closed > .cwm-board-drawer-button-group {
    display: none;
    height: 0;
    width: 0;
}

.cwm-board-drawer-body {
    width: 100%;
    /*display: flex;*/
}
.cwm-board-drawer-button-group {
    display: flex;
    flex-wrap: wrap;
    /*justify-content: stretch;*/
    /*justify-content: space-around;*/
    /*align-items: stretch;*/
    align-items: center;
    box-sizing: border-box;
}
.cwm-drawer-button-wrapper { /* object to show as flex (the button+) */
    display: flex;
    box-sizing: border-box;
    flex: 1 1 35%;
    margin: 5px;
    /*min-width: 25%;*/
    /*padding: .4em;*/
}

.cwm-board-drawer-close-button {
    height: 2em;
    background-color: var(--secondary-color);
}

.cwm-board-drawer-expand-button {
    width: 4em !important;
    /*background-color: yellow;*/
}

.cwm-board-modal-side-drawer h2 {
    flex: 0;
    display: block;
    width: 100%;
    text-align: center;
    margin-bottom: 1em;
    margin-top: 0;
    border: 2px solid var(--primary-color);
    border-bottom-right-radius: 20px;
    background-color: var(--secondary-color);
}
.cwm-board-modal-side-drawer.closed h2 {
    writing-mode: vertical-rl;
    transform: rotate(180deg);
    border-bottom-right-radius: 0;
    padding: .2em;
    height: 98vh;
    min-height: 98vh;
    font-style: italic;
    margin: 0;
    /*width: max-content;*/
    /*min-width: max-content;*/
    width: 1.6em;
    min-width: 1.6em;
}

/***********************************************/
.cwm-board-expanded-section {
    box-sizing: border-box;
    z-index: 2000;
    background-color: orangered;
    min-width: 250px;
    max-width: 80%;
    border: var(--border-one);
    margin: 0;
    padding: 0;
    border: 2px solid var(--primary-color);
    position: absolute;
}

/** Sharing Modal - use for Rooms Members and Boards **/
.cwm-user-select-modal {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 60%;
    height: 40%;
    box-shadow: var(--primary-color) -.2em -.2em 1em .2em;
    background-color: var(--background-color);
    color: var(--primary-color);
    border: var(--border-one);
    border-radius: var(--border-radius-md);
    padding: 1em;
    z-index: 1000;
}

/** Underlay for the modal **/
.cwm-modal-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: hotpink;
    opacity: 0.5;
    z-index: 999;
    display: none;
}

.cwm-user-select-modal > h2 {
    width: 100%;
    text-align: center;
    margin-bottom: 1em !important;
    /*margin-left: 0;*/
    /*margin-right: 0;*/
    padding: 0;
    background-color: var(--secondary-color);
    color: var(--primary-color);
    border-bottom: var(--border-one);
}

.cwm-user-select-modal > dataList {
    background-color: var(--secondary-color);
    /*z-index: 2000;*/
}

.cwm-user-select-modal input {
    text-align: center;
    font-size: x-large;
    font-weight: bold;
    background-color: var(--background-color);
    color: var(--primary-color);
    border: 1px solid var(--accent-color);
    width: 90%;
}

/** TODO: for small screens, make the menu 100% width / with flex rows **/
/*.cwm-board-button-menu-new {*/
/*    position: absolute;*/
/*    z-index: 9999;*/
/*    background-color: var(--secondary-color);*/
/*    min-width: 200px;*/
/*    min-height: 400px;*/
/*    max-width: 30%;*/
/*    border: var(--border-one);*/
/*    margin: 0;*/
/*    padding: 0;*/
/*}*/
.cwm-board-button-menu {
    box-sizing: border-box;
    z-index: 9999;
    background-color: var(--secondary-color);
    min-width: 250px;
    max-width: 30%;
    border: var(--border-one);
    margin: 0;
    padding: 0;
    border: 2px solid var(--primary-color);
    position: absolute;
}

.cwm-board-button-menu > hr {
    width: 100%;
    color: var(--accent-color);
    margin: 0;
    height: 2px;
}

.cwm-board-button-menu > button {
    display: inline-block;
    box-sizing: border-box;
    width: 100%;
    height: 2.2em;
    background-color: var(--secondary-color);
    color: var(--primary-color);
    border-left: none;
    border-right: none;
    border-top: none;
    border-bottom: 2px solid var(--primary-color);
    text-align: left;
    text-indent: 1em;
    appearance: none;
    -webkit-appearance: none; /* For Safari */
    -moz-appearance: none; /* For Firefox */
    padding: 0;
    margin: 0;
    font: inherit; /* To inherit font styles from the parent element */
    cursor: pointer; /* To ensure it still looks clickable */
}
.cwm-board-button-menu > button:hover {
    background-color: var(--primary-color);
    color: var(--secondary-color);
}

.cwm-board-button-menu > li {
    box-sizing: border-box;
    border: 1px solid #444;
    padding: 4px 10px 4px 10px;
    cursor: pointer;
    text-align: left;
    font-size: large;
    text-overflow: ellipsis;
    text-overflow-ellipsis: ellipsis;
}
.cwm-board-button-menu > li:hover {
    background-color: var(--accent-color);
    cursor: pointer;
    border: 1px solid var(--accent-color);
}
/***************************************/
/*************** Say-It  ***************/
/***************************************/
#cwm-say-it {
    box-sizing: border-box;
    width: 100%;
    margin: 0;
    height: 100%;
    border: var(--border-one);
    background-color: var(--background-color);
}
#cwm-say-it-text {
    box-sizing: border-box;
    border: 1px solid var(--secondary-color);
    outline: none;
    -webkit-box-shadow: none;
    -moz-box-shadow: none;
    box-shadow: none;
    width: calc(100% - 85px);
    margin-right: 0;
    height: 100%;
    vertical-align: top;
    background-color: transparent;
    font-size: larger;
    resize: none;
    color: var(--primary-color);
}
#cwm-say-it-send {
    box-sizing: border-box;
    box-shadow: none;
    color: var(--primary-color);
    background-color: var(--secondary-color);
    border-left: 1px solid var(--primary-color);
    border-right: 0;
    border-top: 0;
    border-bottom: 0;
    width: 85px;
    height: 100%;
    margin-left: 0;
    font-size: x-large;
    font-family: Geneva, Arial, Helvetica, sans-serif;
}
#cwm-say-it-send:hover {
    text-decoration: underline;
    box-shadow: -20px 0 40px var(--secondary-color);
}

/***************************************/
/************* Dashboard  **************/
/***************************************/
.cwm-dashboard--original {
    width: 100%;
    padding: 8px;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    align-items: normal;
    align-content: normal;
    list-style-type: none;
    list-style-position: inside;
}
.cwm-dashboard {  /**Apr28 Edit**/
    display: flex;
    justify-content: center;
    align-items: stretch;
    flex-wrap: wrap;
    /* flex-grow, flex-shrink, flex-basis */
    /*flex: 0 1 calc(33.33% - 10px);*/
    box-sizing: border-box;
    width: 100%;
    margin: 0;
}
.cwm-dashboard-block {
    box-sizing: border-box;
    border: var(--border-two);
    padding: 0 0 10px 0;
    display: block;
    margin: 1em;
    align-self: auto;
    order: 0;
    text-align: center;
    list-style-type: none;
    list-style-position: inside;
    /* flex-grow, flex-shrink, flex-basis */
    flex: 1 1 calc(33.33% - 10px);
}
.cwm-dashboard-block h2 {
    width: 100%;
    text-align: center;
    margin: 0;
    background-color: var(--secondary-color);
    border-bottom: var(--border-two);
}
.cwm-dashboard-block-buttons, .cwm-user-select-modal > .buttons {
    display: flex;
    justify-content: center;
    align-items: stretch;
    flex-wrap: wrap;
    margin: 0;
    padding: 0;
}
.cwm-dashboard-block-buttons button, .cwm-dashboard-block a, .cwm-user-select-modal > .buttons > button {
    margin: 1em;
    padding: 1em;
    min-width: 36%;
    max-width: 90%;
    border: var(--border-one);
    background-color: var(--secondary-color);
    color: var(--primary-color);
    font-size: large;
    font-family: Geneva, Arial, Helvetica, sans-serif;
    cursor: pointer;
    align-items: stretch;
}
.cwm-dashboard-block button:hover {
    border: var(--border-one-hover);
    background-color: var(--primary-color);
    color: var(--secondary-color);
}
.cwm-dashboard-block-burger {
    color: var(--secondary-color);
    border-color: var(--secondary-color);
}
.cwm-dashboard-block-burger:hover {
    color: var(--primary-color);
    /*background-color: magenta;*/
    border-color: var(--primary-color) !important;
}

.cwm-dashboard-block-burger {
    width: 35px;
    height: 20px;
    position: relative;
    display: inline-block;
}

.cwm-dashboard-block-burger div {
    width: 100%;
    height: 3px;
    background-color: var(--primary-color);
    position: absolute;
    left: 0;
    transition: all 0.3s;
}

.cwm-dashboard-block-burger div:hover {
    background-color: var(--accent-color);
}

.cwm-dashboard-block-burger div:nth-child(1) {
    top: 0;
}

.cwm-dashboard-block-burger div:nth-child(2) {
    top: 50%;
    transform: translateY(-50%);
}

.cwm-dashboard-block-burger div:nth-child(3) {
    bottom: 0;
}
.cwm-dashboard-block-header {
    background-color: var(--secondary-color);
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    flex-wrap: nowrap;
    padding: .4em;
    border-bottom: var(--border-two);
    height: 2.2em;
}
.cwm-dashboard-block-header h3 {
    flex-grow: 1;
    margin: 0;
    padding: 0;
    text-align: center;
    color: var(--primary-color);
}
.cwm-dashboard-block-header button {
    color: var(--primary-color);
    background-color: var(--background-color);
    height: 1.6em;
    padding: .1em;
    font-size: large;
    border: var(--border-one);
}
.cwm-dashboard-block-form {
    display: flex;
    flex-direction: column;
    justify-content: left;
    align-items: center;
    flex-wrap: nowrap;
    padding: 1em;
}

.cwm-dashboard-block-form input {
    width: 100%;
    max-width: 100%;
    margin: .5em;
    padding: .5em;
    font-size: large;
    border: var(--border-one);
    background-color: var(--background-color);
    color: var(--primary-color);
}


/*******************************************************/
/*********************** Settings **********************/
/*******************************************************/
#cwm-settings {
    box-sizing: border-box;
    width: 100%;
    height: 100vh;
    padding: 0 10% 0 5%;
}
/**Size of the color sample box**/
.cwm-settings-color-picker {
    width: 2em;
    height: 2em;
}

.cwm-page-heading {
    width: 100%;
    /*background-color: yellow;*/
    /*background-color: var(--secondary-color);*/
}

#cwm-settings h1 {
    display: inline-block;
    margin-left: .5em;
}

#cwm-settings-refresh-btn {
    border: 2px solid var(--secondary-color);
    background-color: var(--secondary-color) !important;
    border-radius: var(--border-radius-sm);
    clear: both;
    width: 1.4em !important;
    height: 1.4em !important;
    line-height: 1.2em;
    text-align: center;
    font-size: xx-large;
    padding: 0;
    border: var(--border-one);
    cursor: pointer !important;
}
#cwm-settings-refresh-btn:hover {
    background-color: var(--primary-color) !important;
    border: 2px solid var(--primary-color);
    /*rotate: 90deg;*/
}

#cwm-settings h2 {
    width: 100%;
    background-color: var(--secondary-color);
}

.cwm-settings-table {
    width: 100%;
    border-collapse: collapse;
}

.cwm-settings-input {
    font-size: x-large !important; /** what was over-riding this **/
    caret-color: var(--secondary-color);
    caret-shape: block;
}

/***********************************/
/** Settings > Range Slider       **/
/***********************************/
.cwm-settings-input[type=range] {
    -webkit-appearance: none;
}

/**This is the part that you move**/
.cwm-settings-input[type=range]::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 2em;
    height: 1em;
    border-radius: 20%;
    background: var(--primary-color);
    cursor: pointer;
}

.cwm-settings-td-key {
    border: var(--extra-borders);
    width: 30%;
    text-align: right;
    padding: 10px 15px 0 0;
}
.cwm-settings-td-value {
    width: 40%;
    padding: 10px 0 0 15px;
}
.cwm-settings-td-delta {
    width: 20%;
    padding: 10px;
}
.cwm-settings-td-value > select, .cwm-settings-td-value > input, .cwm-settings-td-value > input[type=range] {
    border: 1px solid var(--accent-color);
    background-color: var(--background-color);
    color: var(--primary-color);
    /*min-width: 50%;*/
    width: 100%;
    font-size: large;
    margin: 0;
}
#cwm-settings-save-button-div {
    width: 100%;
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid var(--accent-color);
    display: flex;
    justify-content: center;
    position: relative;
}
#cwm-settings-save-button-div > button {
    background-color: var(--accent-color);
    border: var(--border-one);
    color: var(--primary-color);
    min-width: 25%;
    font-size: x-large;

}
#cwm-settings-save-button-div > span {
    position: absolute;
    right: 10px;
    font-style: oblique;
}

#cwm-settings-save-button-div > button:hover {
    background-color: var(--primary-color);
    color: var(--secondary-color);
}


.cwm-save-status-ok {
    color: green;
}
/*.cwm-settings-color-select {*/
/*    width: 100%;*/
/*}*/

/*******************************************************/
/******************* Room Page (CRUD) ******************/
/*******************************************************/
/*#cwm-room-page-container {*/
/*}*/

#cwm-room-details-basic-info-list {
    display: flex;
    flex-wrap: nowrap;
    flex-direction: column;
    flex: 1 1 100%;
    list-style-type: none;
    margin: 1em;
    max-width: 100%;
    text-align: left;
}

#cwm-room-details-basic-info-list li {
    display: flex;
    flex-direction: row;
    flex: 1;
    border-bottom: 1px dotted var(--accent-color);
    margin-bottom: 1em;
    padding: 0;
    vertical-align: top;
}
#cwm-room-details-basic-info-list-description {
    display: flex;
    flex: 1;
    min-width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}
#cwm-room-details-basic-info-list-description textarea {
    font-size: large;
    background-color: var(--background-color);
    width: 100%;
    resize: vertical;
    min-height: 4.8em;
    box-sizing: border-box;
    color: var(--primary-color);
    border: var(--border-one);
}

#cwm-room-detail-members-table {
    border-collapse: collapse;
    min-width: 80%;
    max-width: 80%;
    margin: .5em;
}
#cwm-room-detail-members-table tr {
    border-bottom: var(--border-one);
    vertical-align: center;
}
#cwm-room-detail-members-table td {
    vertical-align: bottom;
}
#cwm-room-detail-members-table input {
    width: 100%;
    /*border: var(--border-one);*/
    border: none;
    background-color: var(--background-color);
    color: var(--primary-color);
    font-size: large;
    padding: 5px;
}
#cwm-room-detail-members-table button {
    width: 100%;
    box-sizing: border-box;
}
.cwm-room-detail-member-removed {
    text-decoration: line-through;
    font-style: italic;
}
/*******************************************************/
/********************** Debug Page *********************/
/*******************************************************/
#debug {
    margin: 30px;
    border: var(--border-two);
    padding: 20px;
    font-size: larger;
    max-width: 100%;
}
#debug h2 {
    display: block;
    width: 100%;
    margin: 0;
    text-align: center;
    border-bottom: 1px solid var(--accent-color);
}
#debug pre {
    margin: 20px;
    line-height: 1.8em;
    overflow: hidden;
    white-space: pre-wrap;
}
#debug button {
    background-color: var(--primary-color);
    color: var(--secondary-color);
    font-size: x-large;
    border: var(--border-one);
    min-width: 25%;
    margin: 10px;
}
#debug button:hover {
    background-color: var(--secondary-color);
    color: var(--primary-color);
}
#debug p {
    font-style: oblique;
    font-size: small;
    font-weight: lighter;
    overflow-wrap: break-word;
    width: auto;
}
.cwm-board-header-edit-container {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    flex-wrap: nowrap;
    padding: 0;
    margin: 0;
    background-color: var(--secondary-color);
    color: var(--primary-color);
    /*height: 2em;*/
}
.cwm-board-header-edit-container button {
    box-sizing: border-box;
    font-size: x-large;
    margin: 0;
    flex: 0;
    background-color: var(--background-color);
    color: var(--primary-color);
    border-color: var(--primary-color);
    border: 1px solid;
    width: 3em;
}
.cwm-board-header-edit-container button:hover {
    background-color: var(--primary-color);
    color: var(--secondary-color);
}
.cwm-board-header-edit-container input {
    box-sizing: border-box;
    /*width: 100%;*/
    text-align: center;
    font-size: x-large;
    font-weight: bold;
    background-color: var(--background-color);
    color: var(--primary-color);
    flex: 1 1 100%;
}

/*******************************************************/
/************ Indicators set by cwm-socket *************/
/*******************************************************/
:root {
    /** TODO: how do we make these even with the extra border? see mdn chat **/
    --cwm-chat-control-button-width: 25%;
    --cwm-chat-control-button-height: 40px;
}

.cwm-chat-socket-indicator {
    border: 5px solid var(--primary-color);
    /*box-sizing: border-box;*/
    min-width: var(--cwm-chat-control-button-width);
    /*height: calc(var(--cwm-chat-control-button-width) + 10)*/
}
.cwm-chat-socket-indicator-on {
    border-color: #0b0;
}
.cwm-chat-socket-indicator-on:hover {
    border-color: #0f0;
}
.cwm-chat-socket-indicator-off {
    border-color: #b00;
    font-weight: bolder;
}
.cwm-chat-socket-indicator-off:hover {
    border-color: #f00;
}


.cwm-room-details-table  {
    border: var(--border-one);
    border-collapse: collapse;
    min-width: 80%;
    margin-left: 5%;
}
.cwm-room-details-table th, .cwm-room-details-table td {
    padding: 10px;
    border: var(--border-one);
    text-align: center;
}
.cwm-room-details-table th
{
    background-color: var(--secondary-color);
    color: var(--primary-color);
}

/*******************************************************/
/**************** General Form Styles ******************/
/*******************************************************/
#cwm-input-field-ok {
    border: 2px solid #0f0 !important;
    background-color: #080 !important;
}
.cwm-input-field-error {
    border-color: red !important;
}

/*******************************************************/
/**************** Developer Utilities *(****************/
/*******************************************************/
#cwm-developer-raw-data {
    margin: 30px;
    border: var(--border-two);
    font-family: monospace;
}
#cwm-developer-raw-data > h3 {
    border-bottom: var(--border-two);
    text-align: center;
    cursor: crosshair;
}
#cwm-developer-raw-data pre {
    line-height: 2.2em;
}