@import url("normalize.css"); @import url("@fortawesome/fontawesome-free/css/fontawesome"); @import url("@fortawesome/fontawesome-free/css/brands"); @import url("@fortawesome/fontawesome-free/css/solid"); @import url("../dependencies/animate"); @import url("../dependencies/jquery-ui"); @import url("../media_queries"); @import url("../fonts"); @import url("../base"); @import url("../utilities"); :root { --animate-duration: 300ms; --font-family: "Exo", system-ui; --font-family-monospace: "Inconsolata", "Lucida Console", "Monaco", monospace; --color-text: #7c7c7c; --color-text-link: #326b9b; --color-text-link-hover: #c36; --color-background: #fff; /* Alerts */ --alert-border-color: #fff; --alert-box-shadow: 0 2px 4px rgb(0 0 0 / 20%); --alert-text-shadow: 0 1px rgb(0 0 0 / 45%); --alert-info-color: #618ecc; --alert-danger-color: #ec6c6c; --alert-success-color: #5ea64c; /* Icons */ --icon-color-teal: #3cc; --icon-color-purple: #8e2fca; --icon-color-maroon: #c36; --icon-color-red: #f33; --icon-color-green: #53ba55; --icon-color-orange: #ffc043; --icon-color-blue: #326b9b; --icon-color-lightblue: #6eb6f0; } .check-label { display: inline-block; cursor: pointer; position: relative; line-height: 16px; padding-left: 26px; &::before { content: ""; size: 16px; position: absolute; left: 0; top: 0; display: inline-block; z-index: 2; } } .clicked-on.check-label::before, .selected .check-label::before { content: ""; display: inline-block; size: 27px; background-position: -225px -42px; top: -6px; left: -6px; } .app-header { padding-top: 40px; } .container { margin-left: auto; margin-right: auto; max-width: 1024px; } /* Top bar ========================================================================== */ .top-bar { background: linear-gradient( to bottom, rgb(104 145 196 / 100%) 0%, rgb(69 114 181 / 100%) 50%, rgb(65 90 149 / 100%) 100% ); background-color: #5070a6; box-shadow: 0 4px 10px rgb(100 100 100 / 40%); border-bottom: 1px solid #fff; position: fixed; display: flex; size: 100% 40px; z-index: 2; top: 0; } .top-bar-inner { display: flex; flex-grow: 1; padding-left: 20px; padding-right: 20px; justify-content: space-between; @media (--viewport-large) { padding-left: 0; padding-right: 0; } } .top-bar-left { display: flex; } .top-bar-logo { display: flex; align-items: center; margin-right: 30px; } .top-bar-usage { display: none; @media (--viewport-small) { display: flex; align-items: center; } } .top-bar-usage-inner { display: flex; color: #fff; text-shadow: 1px 1px rgb(0 0 0 / 25%); font-weight: 500; } .top-bar-usage-item { margin-right: 11px; &:last-child { margin-right: 0; } & .fas { margin-right: 3px; } } .top-bar-right { display: flex; } .top-bar-notifications { display: flex; position: relative; } .top-bar-notifications-list { background-color: #fff; box-shadow: 0 3px 20px 0 rgb(0 0 0 / 40%); max-height: 500px; overflow-y: auto; position: absolute; top: 100%; right: 0; width: 280px; z-index: 1; border-bottom-left-radius: 6px; border-bottom-right-radius: 6px; border: 1px solid #fff; border-top: none; @media (--viewport-small) { width: 330px; } @media (--viewport-medium) { width: 400px; } } .top-bar-notification-item { color: #6f6f6f; font-size: 0.8rem; border-bottom: 1px solid #e9e4e4; padding: 15px; &:last-child { border-bottom: none; } &.empty { text-align: center; font-size: 1.2rem; font-weight: normal; padding: 4rem; & .fas { font-size: 4rem; margin-bottom: 20px; } } &.unseen { & .top-bar-notification-title { color: #c36; } & .top-bar-notification-delete { display: block; } } & a { font-weight: 600; } } .top-bar-notification-timestamp { font-size: 0.75rem; font-weight: 600; text-align: right; margin-top: 10px; } .top-bar-notification-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; } .top-bar-notification-title { color: #9e9e9e; font-size: 0.85rem; font-weight: 600; & a { color: #9e9e9e; } } .top-bar-notification-delete { display: none; background-color: transparent; border: 0; padding-left: 5px; padding-right: 5px; & .fas { color: #c36; font-size: 0.9rem; } &:hover .fas { opacity: 0.8; } } .top-bar-notification-delete-all { display: block; background-color: transparent; border: 0; color: inherit; width: 100%; text-align: center; padding: 10px 15px; &:hover { background-color: rgb(0 0 0 / 5%); } & .fas { color: #c36; margin-right: 5px; } } .top-bar-menu { display: flex; position: relative; } .top-bar-menu-list { display: block; background-color: #4673b6; box-shadow: 0 3px 20px 0 rgb(0 0 0 / 40%); position: absolute; top: 100%; right: 0; @media (--viewport-medium) { display: flex !important; /* NOTE: Overrides inline style set by JS */ background-color: transparent; box-shadow: none; position: static; } } .top-bar-menu-item { @media (--viewport-medium) { display: flex; } } .top-bar-menu-link { color: #f7f7f7; display: flex; align-items: center; font-size: 0.8rem; font-weight: 600; text-shadow: 1px 1px rgb(0 0 0 / 25%); background-color: transparent; border: 0; border-left: 1px solid transparent; border-right: 1px solid transparent; padding: 10px; &:hover { box-shadow: inset 0 0 6px rgb(255 255 255 / 60%); transition: 0.2s; color: #4686b8; border-left: 1px solid rgb(0 0 0 / 10%); border-right: 1px solid rgb(0 0 0 / 10%); background: linear-gradient( to bottom, rgb(255 255 255 / 60%) 0%, rgb(255 255 255 / 75%) 30%, rgb(255 255 255 / 100%) 95% ); text-shadow: 0 1px rgb(255 255 255 / 80%); } &:active { color: #046c98; border-left: 1px solid rgb(0 0 0 / 15%); border-right: 1px solid rgb(0 0 0 / 15%); text-shadow: 0 -1px 1px rgb(255 255 255 / 50%); background: linear-gradient( to bottom, rgb(255 255 255 / 50%) 0%, rgb(255 255 255 / 60%) 30%, rgb(255 255 255 / 95%) 95% ); box-shadow: inset 0 0 1px #fff, inset -1px -1px 4px rgb(220 220 220 / 40%); transition: 0.2s; } &.active { color: #4686b8; background: linear-gradient( to bottom, rgb(255 255 255 / 60%) 0%, rgb(255 255 255 / 75%) 30%, rgb(255 255 255 / 100%) 95% ); text-shadow: 0 1px rgb(255 255 255 / 80%); border-left: 1px solid rgb(255 255 255 / 98%); border-right: 1px solid rgb(255 255 255 / 98%); } & .fas { font-size: 1.1rem; } } .top-bar-menu-link-logout { color: #dbf94e; } .top-bar-menu-link-label { margin-left: 6px; white-space: nowrap; @media (--viewport-medium) { display: none; } @media (--viewport-large) { display: inline; } } /* Main menu ========================================================================== */ .main-menu { @media (--viewport-medium) { padding-top: 10px; } } .main-menu-toggle { border: 0; background-color: transparent; padding: 10px; display: block; width: 100%; &:hover { background-color: rgb(0 0 0 / 5%); & .main-menu-toggle-label { color: #c36; } } & .fas { color: #999; margin-right: 5px; } @media (--viewport-small) { display: none; } } .main-menu-toggle-label { color: #5b5b5b; font-weight: 600; } .main-menu-list { display: block; border-top: 1px solid #ddd; @media (--viewport-small) { border-top: 0; display: flex !important; /* NOTE: Overrides inline style set by JS */ justify-content: space-evenly; } } .main-menu-item { @media (--viewport-small) { flex-grow: 1; } @media (--viewport-medium) { flex-grow: 0; display: flex; &.focus { & .main-menu-item-link { border-bottom-color: #5edad0; } & .main-menu-item-label { color: #5edad0; } } } } .main-menu-item-link { display: block; text-align: center; padding: 10px; &:hover { background-color: rgb(0 0 0 / 5%); & .main-menu-item-label { color: #c36; } } &.active { & .main-menu-item-label { color: #c36; & .fas { color: #c36; } } } @media (--viewport-small) { padding-top: 20px; padding-bottom: 20px; } @media (--viewport-medium) { border-bottom: 4px solid #fff; &:hover, &.active { background-color: transparent; border-bottom-color: #c36; transition: 0.3s; } } @media (--viewport-large) { padding-left: 30px; padding-right: 30px; } } .main-menu-item-label { color: #5b5b5b; font-weight: 600; & .fas { color: #999; margin-left: 5px; } @media (--viewport-medium) { font-size: 1rem; & .fas { margin-left: 10px; } } } .main-menu-stats { display: none; @media (--viewport-medium) { color: var(--color-text); display: block; font-size: 0.75rem; text-transform: lowercase; line-height: 1.8; padding-top: 10px; padding-bottom: 10px; } } /* Toolbar ========================================================================== */ .toolbar { background-color: #fff; border-top: 1px solid #ddd; border-bottom: 1px solid #ddd; & .form-select { color: inherit; padding-top: 4px; padding-bottom: 4px; box-shadow: none; border-color: #ddd; border-right-color: transparent; border-top-right-radius: 0; border-bottom-right-radius: 0; &:focus { box-shadow: none; } } & .form-control { padding-top: 4px; padding-bottom: 4px; box-shadow: none; border-color: #ddd; border-right-color: transparent; border-top-right-radius: 0; border-bottom-right-radius: 0; &:hover { border-right-color: #94c8f0; } &:focus { border-right-color: #008fee; } } @media (--viewport-large) { position: sticky; z-index: 1; top: 39px; height: 45px; display: flex; justify-content: center; align-items: center; &.active { box-shadow: 0 4px 6px rgb(0 0 0 / 10%); } } } .toolbar-inner { padding: 10px 20px; @media (--viewport-large) { display: flex; justify-content: space-between; align-items: center; flex-grow: 1; max-width: 1024px; padding: 5px 0; } } .toolbar-right { & form { display: flex; } @media (--viewport-large) { display: flex; } } .toolbar-sorting { position: relative; font-size: 0.8rem; padding-bottom: 5px; & form { flex-grow: 1; } @media (--viewport-small) { display: flex; align-items: center; & form { margin-left: 10px; } } @media (--viewport-large) { padding-bottom: 0; } } .toolbar-sorting-toggle { color: var(--color-text); display: block; padding-bottom: 5px; text-transform: uppercase; &:hover { color: #4b4b4b; & b { color: #4b4b4b; } } &:active { color: #3b9de8; & b { color: #3b9de8; } } & b { padding-left: 3px; } @media (--viewport-small) { padding-bottom: 0; } } .toolbar-sorting-menu { position: absolute; top: 25px; left: 0; z-index: 1; overflow: hidden; border-radius: 4px; border: 1px solid rgb(255 255 255 / 100%); background-color: rgb(255 255 255 / 95%); box-shadow: 0 2px 14px 0 rgb(20 20 20 / 35%); & li { border-bottom: 1px solid #ddd; color: #2e2e2e; cursor: pointer; &:last-child { border-bottom: none; } } & span { &.name { display: inline-block; padding: 11px; width: 141px; font-weight: 500; & .fas.fa-arrow-down-a-z { float: right; margin-top: 2px; } } &.up { display: inline-block; padding: 11px 14px; width: 44px; } &.active { background-color: #4f8bbc; color: #4686b8; background: linear-gradient( to bottom, rgb(255 255 255 / 60%) 0%, rgb(255 255 255 / 75%) 50%, rgb(255 255 255 / 95%) 95% ); text-shadow: 0 1px rgb(255 255 255 / 80%); } &:hover { color: #3b9de8; text-shadow: 1px 1px rgb(255 255 255 / 50%); background: linear-gradient( to bottom, rgb(241 248 253 / 100%) 0%, rgb(218 236 250 / 100%) 50%, rgb(190 221 246 / 100%) 51%, rgb(227 240 251 / 100%) 100% ); box-shadow: inset 0 0 1px #fff, inset 0 0 6px rgb(255 255 255 / 60%); transition: 0.2s; } &:active, &:focus { background: linear-gradient( to bottom, rgb(210 232 250 / 100%) 0%, rgb(187 220 247 / 100%) 50%, rgb(162 207 244 / 100%) 51%, rgb(194 224 248 / 100%) 100% ); color: #046c98; text-shadow: 0 -1px 1px rgb(255 255 255 / 50%); box-shadow: inset 0 0 1px #fff, inset -1px -1px 4px rgb(220 220 220 / 40%); } } @media (--viewport-small) { top: 35px; } } .toolbar-input-submit { display: flex; align-items: center; border: 1px solid #ddd; border-left: 0; background-color: rgb(255 255 255 / 90%); border-radius: 0 4px 4px 0; box-shadow: inset 0 0 1px rgb(41 90 152 / 10%), inset 0 0 2px rgb(255 255 255 / 100%); text-shadow: 1px 1px rgb(255 255 255 / 90%); color: #069; min-width: 32px; padding: 0 10px; font-size: 0.75rem; &:hover { color: #39c; background-color: #fff; } &:active { color: #409fd5; box-shadow: inset 1px 1px 0 rgb(0 0 0 / 10%); } } .toolbar-link { display: block; padding: 6px 12px; color: #777; text-transform: uppercase; font-weight: 600; &.selected { color: #c36; } &:hover { color: #c36; } &:active { color: #3b9de8; } } .toolbar-buttons { padding-bottom: 10px; &:last-child { padding-bottom: 0; } & .button { min-width: 0; width: 100%; margin-bottom: 5px; padding: 2px 10px; &:last-child { margin-bottom: 0; } } @media (--viewport-medium) { display: flex; align-items: center; & .inline-alert { margin-right: 20px; } & .button { margin-bottom: 0; margin-right: 8px; &:last-child { margin-right: 0; } } } @media (--viewport-large) { padding-bottom: 0; & .button { width: auto; } } } .toolbar-search { @media (--viewport-large) { margin-left: 12px; } } /* Cards ========================================================================== */ .cards { @media (--viewport-small) { display: grid; gap: 25px; grid-template-columns: repeat(2, 1fr); } @media (--viewport-medium) { grid-template-columns: repeat(4, 1fr); } } .card { overflow: hidden; background-color: #f5f5f5; border: 1px solid #d3d3d3; box-shadow: 0 1px 4px rgb(0 0 0 / 20%); border-radius: 4px; margin-bottom: 20px; @media (--viewport-small) { margin-bottom: 0; } &.disabled { color: #b6b6b6; & .card-thumb { filter: grayscale(100%); opacity: 0.3; } } } .card-thumb { background-color: #fff; display: flex; align-items: center; justify-content: center; height: 180px; padding: 20px; & img { max-width: 100%; max-height: 100%; } } .card-content { padding: 10px; color: #353535; border-top: 1px solid #e6e6e6; text-align: center; } .card-title { font-size: 1rem; font-weight: 600; } .body-user .l-unit.animate__animated.animate__fadeIn { line-height: 2rem; } .body-user .actions-panel { line-height: 2rem; } .l-unit { color: #707070; padding: 0 0 0 14px; overflow: hidden; font-size: 0.8rem; border-radius: 0; border-left: 1px solid transparent; border-right: 1px solid transparent; } .table-header { font-size: 0.8rem; background: linear-gradient(to bottom, rgb(247 247 247 / 100%) 0%, rgb(255 255 255 / 100%) 100%); background-color: #fff; border-left: 1px solid #d0d0d0; border-right: 1px solid #d0d0d0; border-bottom: 1px solid #d0d0d0; text-shadow: 0 1px rgb(255 255 255 / 100%); box-shadow: inset 0 1px 1px rgb(255 255 255 / 100%), inset 0 0 1px rgb(255 255 255 / 100%), inset 0 0 4px rgb(255 255 255 / 80%), 0 1px 4px rgb(140 140 140 / 35%); border-radius: 0 0 6px 6px; min-height: 28px; color: #707070; padding: 0 0 0 14px; overflow: hidden; width: 1024px; line-height: 1rem; padding-top: 4px; padding-bottom: 4px; & .fas { font-size: 1rem; } @media (--viewport-large) { &.active { position: fixed; top: 84px; z-index: 1; } } } .units { overflow-x: auto; padding-left: 20px; padding-right: 20px; padding-bottom: 20px; @media (--viewport-large) { padding-left: 0; padding-right: 0; padding-bottom: 0; } } .units .l-unit { border-bottom: 1px solid #ddd; border-left: 1px solid transparent; border-right: 1px solid transparent; width: 1024px; } .l-unit:hover, .units .l-unit:hover { box-shadow: 0 2px 10px rgb(150 150 150 / 20%); background-color: #f8f8f8; text-shadow: 0 1px rgb(255 255 255 / 50%); border-left: 1px solid #ddd; border-right: 1px solid #ddd; } .units .l-unit.l-unit--starred { border-left: 2px solid #c36; } .units.active .l-unit.focus { border-left: 2px solid #5edad0; background-color: #eff5fc; } .units.active .l-unit.focus .l-unit__name { color: #36b3a9; } .units.active .l-unit.focus .l-unit-toolbar__col--right { display: block; } .units > div:last-child { border-bottom: none; } .l-unit:hover .l-unit-toolbar__col--right { display: block; } .l-unit--blue { border-left: 2px solid #3b9de8; } .l-unit--suspended { background-color: #eaeaea !important; color: #c0c0c0; & a { color: #c0c0c0 !important; } } .units .l-unit.l-unit--outdated { background-color: #ffcaca; color: #4b4b4b; } .body-updates .units .l-unit.l-unit--outdated .fas.fa-box-open { color: #da1010; } .l-unit--suspended .l-unit__name, .l-unit--suspended b, .l-unit--outdated .l-unit__name, .l-unit--outdated b { color: #c0c0c0; } .l-unit--outdated .l-unit__name { color: #333; } .l-unit--outdated b { color: #4b4b4b; } .l-unit--suspended .l-percent { border-color: #fff; } .l-unit--suspended .l-percent__fill { background-color: #fff; } .l-unit--suspended .l-unit__name, .l-unit--suspended .l-unit__name span { color: #adadad; } .l-unit--suspended.selected { background-color: #f2eab8 !important; color: #b2ac87 !important; } .l-unit--outdated.selected { background: #ff9494 !important; color: #333 !important; text-shadow: none !important; } .l-unit--suspended.selected b, .l-unit--outdated.selected .l-unit__name, .l-unit--outdated.selected b, .l-unit--suspended.selected .l-percent, .l-unit--suspended.selected .l-percent__fill, .l-unit--suspended.selected .l-unit__name, .l-unit--suspended.selected .l-unit__name span { color: #333 !important; } .l-unit.selected .l-percent { border-bottom: 1px dotted #777; } .l-unit--selected { background-color: #d1eddc; } .l-unit-toolbar { display: none; } .l-unit label { margin-bottom: 20px; } .l-unit__columns { display: table; width: 100%; } .l-unit__col { display: table-cell; padding-top: 12px; vertical-align: top; padding-bottom: 10px; } .l-unit__col--left { width: 110px; padding-right: 10px; } .units.compact .l-unit__col--left { vertical-align: top; } .l-unit__col--right.total { padding-left: 16px; } .l-unit__suspended { display: none; font-size: 0.8rem; font-weight: 600; margin-top: 36px; text-transform: uppercase; margin-bottom: 14px; } .units.compact .l-unit__suspended { margin-top: 1px; } .l-unit--outdated .l-unit__suspended, .l-unit--suspended .l-unit__suspended { display: block; } .l-unit__name { color: #414141; font-size: 1.4rem; margin-top: 10px; margin-bottom: 10px; font-weight: 500; letter-spacing: -0.02em; } .l-unit__servername { color: #414141; font-size: 1.7rem; margin-bottom: 10px; font-weight: 300; letter-spacing: -0.02em; } .l-unit__stats.separate, .l-unit__name.separate { padding-bottom: 15px; } .body-stats .l-unit__name { margin-left: -42px; margin-top: 12px; color: #606060; } .l-unit__name span { color: #999; margin-left: 30px; font-style: italic; &:first-of-type { margin-left: 39px; } } .l-unit__name b { font-weight: normal; font-style: italic; } .l-unit__stats { margin-bottom: 10px; margin-left: 15%; border-left: 1px solid transparent !important; border-right: 1px solid transparent !important; &:hover { border-left: 1px solid transparent !important; border-right: 1px solid transparent !important; box-shadow: none !important; background: none !important; } & table { table-layout: fixed; margin-top: -54px; margin-left: -20px; } & td { height: 32px; padding-bottom: 4px; vertical-align: middle; } } .body-stats .l-unit__stat-col--left { width: 180px; } .body-stats .l-unit__stat-col--right { float: right; } .l-unit__stat-col--left a, .l-unit__stat-col--left a:visited { color: #353535; } .l-unit__stat-col--left a:hover { color: #4c8bbe; } .l-unit__stat-col--left { float: left; width: 110px; } .l-unit__stat-col--left.border { border-left: 1px solid #ebebeb; } .l-unit__stat-col--left.border-clear { border-left: 1px solid transparent; } .l-unit__stat-col--left.super-compact { width: 50px; white-space: nowrap; } .l-unit__stat-col--left.compact { width: 60px; } .l-unit__stat-col--left.compact-1 { width: 70px; } .l-unit__stat-col--left.compact-2 { width: 80px; } .l-unit__stat-col--left.compact-3 { width: 90px; } .l-unit__stat-col--left.compact-4 { width: 130px; } .l-unit__stat-col--left.compact-5 { width: 160px; } .l-unit__stat-col--left.wide { width: 190px; } .l-unit__stat-col--left.wide-2 { width: 230px; } .l-unit__stat-col--left.wide-3 { width: 250px; } .l-unit__stat-col--left.wide-4 { width: 320px; } .l-unit__stat-col--left.wide-5 { width: 350px; } .l-unit__stat-col--left.wide-6 { width: 440px; } .l-unit__stat-col--left.wide-7 { width: 550px; } .l-unit__stat-col--right { float: left; max-width: 170px; } .l-unit-toolbar__col--left { float: left; margin-left: -15px; margin-top: 0; padding-bottom: 0; padding-left: 15px; padding-top: 15px; width: 30px; cursor: pointer; display: none; } .l-unit-toolbar__col--right { float: right; } .l-unit-toolbar .shortcut { display: none; } .units.active .l-unit.focus .l-unit-toolbar .shortcut { display: block; background-color: #69a298; border-radius: 13px; color: #fff; cursor: pointer; font-size: 0.8rem; font-weight: 600; line-height: 25px; padding-left: 7px; padding-right: 9px; position: absolute; right: 3px; top: 3px; } .units.active .l-unit.focus .l-unit-toolbar .shortcut.delete { font-size: 10px; padding-left: 2px; padding-right: 5px; text-transform: capitalize; } .units.active .l-unit.focus .l-unit-toolbar .shortcut.enter { font-size: 17px; padding-left: 1px; padding-right: 7px; } .units.active .l-unit.focus .l-unit-toolbar i { background: none; } .actions-panel { line-height: 1.1rem; } .actions-panel__col { display: inline-block; margin-left: 3px; text-transform: uppercase; & a { color: #777; font-weight: 600; font-size: 0.9rem; display: inline-block; cursor: pointer; } } .l-unit__col .actions-panel .fas { display: none; } .l-unit__col:hover .actions-panel .fas { display: inline-block; } .l-unit__stat-cols { padding-right: 10px; } .l-unit__stat-cols.last { padding-right: 0; } .l-unit__stat-cols.graph { width: 242px; } .l-percent { border-bottom: 3px solid #e6e6e6; margin-top: 2px; width: 242px; } .l-percent__fill { background-color: #54e000; height: 3px; position: relative; bottom: -3px; } .statistics-count { min-width: 24px; text-align: right; border-bottom: 1px dotted #ddd; border-right: 1px dotted #ddd; padding-right: 4px; } /* Forms ========================================================================== */ .form-container { max-width: 640px; margin-left: auto; margin-right: auto; padding: 30px 20px; } .form-container-wide { max-width: 920px; } @media (--viewport-medium) { .sidebar-container { display: grid; gap: 50px; grid-template-columns: 2fr 1.3fr; } } .form-title { color: #4b4b4b; font-size: 1.4rem; font-weight: 500; padding-bottom: 30px; letter-spacing: -0.01em; } .form-label { margin-bottom: 5px; display: inline-block; } .form-label, .form-check label { color: #4b4b4b; font-weight: 600; } .form-control { background-color: #fff; border: 1px solid #cfcfcf; display: block; width: 100%; padding: 8px 12px; font-size: 0.8rem; font-weight: normal; color: #4e4e4e; border-radius: 4px; line-height: 1.5; appearance: none; box-shadow: 0 1px 4px rgb(0 0 0 / 15%); &:hover { border-color: #94c8f0; } &:focus { border-color: #008fee; background-color: #d7f9ff; color: #333; } &.list-editor { border-color: transparent; box-shadow: none; position: absolute; padding-top: 7px; padding-bottom: 7px; width: auto; top: 1px; left: 1px; right: 30px; &:hover { border-color: transparent; } &:focus { background-color: #fff; } } } .form-select { display: block; width: 100%; font-weight: normal; font-size: 0.8rem; padding: 8px 30px 8px 12px; line-height: 1.5; border-radius: 4px; background-color: #fff; border: 1px solid #ccc; color: #4e4e4e; appearance: none; background-image: url("/images/arrow.svg"); background-size: 16px auto; background-repeat: no-repeat; background-position: right 9px center; text-shadow: 0 0 0 #4b4b4b; box-shadow: 0 1px 4px rgb(0 0 0 / 15%); &:hover { border-color: #94c8f0; } &:focus { border-color: #008fee; } } .form-check { position: relative; padding-left: 20px; margin-left: 3px; min-height: 24px; } .form-check-input { position: absolute; margin-top: 3px; margin-left: -20px; } .form-control:disabled, .form-select:disabled { background-color: #e7e7e7; text-shadow: 1px 1px rgb(255 255 255 / 100%); color: #686868; } .form-control:focus:disabled { border-color: #dedede; background-color: #f1f1f1; } .form-control:disabled:hover, .form-select:disabled:hover { border-color: #cfcfcf; } .form-link { color: #326b9b; cursor: pointer; text-decoration: underline; font-weight: 600; border-radius: 4px; margin-left: -3px; padding-left: 3px; padding-right: 3px; &:hover { text-decoration: none; color: #fff; background-color: #3b9de8; } &:active { background-color: #54a6e5; } } .form-link-danger { &:hover { background-color: #c36; } &:active { background-color: #f7d616; } } .toggle-password { color: #aaa; z-index: 1; position: absolute; top: 9px; right: 12px; } .toggle-psw-visibility-icon { cursor: pointer; opacity: 1; margin: -2px; } .password-meter { appearance: none; display: block; width: auto; height: 3px; background-color: #e7e7e7; margin-left: 3px; margin-right: 3px; border-bottom-left-radius: 3px; border-bottom-right-radius: 3px; box-shadow: 0 1px 2px rgb(0 0 0 / 25%); &[value="1"] { background: red; } &[value="2"] { background: orange; } &[value="3"] { background: yellow; } &[value="4"] { background: green; } } .unlim-trigger { cursor: pointer; position: absolute; top: 13px; right: 12px; z-index: 1; font-size: 0.8rem; } .optional { font-size: 0.8rem; margin-left: 6px; font-weight: normal; } .hint { color: #777; font-size: 0.8rem; font-style: italic; font-weight: normal; } .hint-prefix { color: #555; font-size: 0.8rem; } .section-title { display: flex; color: #4b4b4b; cursor: pointer; justify-content: space-between; align-items: center; font-size: 1.05rem; font-weight: 600; padding-top: 28px; padding-bottom: 12px; border-bottom: 1px solid #ccc; } /* Modals ========================================================================== */ .dialog { display: none; } /* Hide the default close button in dialog header */ .ui-dialog-titlebar-close { display: none; } /* Set dialog z-index */ .ui-front { z-index: 2; } .ui-dialog { font-family: Exo, system-ui; font-weight: 500; background-color: rgb(255 255 255 / 90%); box-shadow: inset 0 1px 3px rgb(0 0 0 / 25%), 0 8px 40px 0 rgb(0 0 0 / 35%); border-radius: 6px; border: 1px solid rgb(255 255 255 / 98%); text-align: center; } .ui-dialog .ui-dialog-content { color: #535353; padding: 20px 26px 30px; } .ui-dialog .ui-dialog-title { margin: 0; color: #305ba9; font-size: 1rem; text-transform: none; letter-spacing: -0.01em; text-align: center; float: none; font-weight: 500; } .ui-widget-overlay { background-color: rgb(0 0 0 / 60%); } .ui-dialog .ui-dialog-buttonpane { border-color: #fff; box-shadow: inset 0 0 2px rgb(0 0 0 / 25%); margin-top: 0; padding: 0; } .ui-dialog .ui-dialog-buttonpane button { margin: 0.5em 0.5em 0.5em 0; box-shadow: 0 1px 4px rgb(0 0 0 / 20%), inset 0 0 1px #fff, inset 0 0 3px rgb(255 255 255 / 50%); } /* Shortcuts panel ========================================================================== */ .shortcuts { background: rgb(50 50 50 / 93%); color: #eee; border: 1px solid rgb(255 255 255 / 70%); border-radius: 6px; box-shadow: 0 4px 30px rgb(0 0 0 / 50%); & li { padding: 5px 20px; } & .key { color: #ff3478; display: inline-block; font-weight: 600; padding-right: 20px; &.bigger { font-size: 1.1rem; } } } .shortcuts-header { display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid #606060; padding: 10px 10px 10px 20px; } .shortcuts-title { text-transform: uppercase; color: #ff3478; letter-spacing: -0.01em; font-weight: 600; } .shortcuts-close { cursor: pointer; padding: 5px 10px; &:hover { color: #db0000; } &:active { color: #a60000; } } .shortcuts-inner { @media (--viewport-medium) { display: flex; } } .shortcuts-list { flex-grow: 1; padding: 40px; } /* Buttons ========================================================================== */ .button { cursor: pointer; display: inline-block; line-height: 1.5; font-size: 0.85rem; font-weight: 500; padding: 3px 25px; user-select: none; color: #30659d; min-width: 100px; text-align: center; text-shadow: 0 1px 1px rgb(255 255 255 / 85%); border: 1px solid #0083db; border-radius: 3px; background-color: #3b9de8; background: linear-gradient( to bottom, rgb(235 243 249 / 100%) 0%, rgb(192 216 236 / 100%) 51%, rgb(223 235 245 / 100%) 100% ); box-shadow: 0 1px 3px rgb(0 0 0 / 25%), inset 0 0 1px #fff, inset 0 0 3px rgb(255 255 255 / 50%); &:hover { color: #0077c6; text-shadow: 1px 1px rgb(255 255 255 / 50%); border-color: #54a6e5; background: linear-gradient( to bottom, rgb(241 248 253 / 100%) 0%, rgb(190 221 246 / 100%) 51%, rgb(227 240 251 / 100%) 100% ); box-shadow: 0 1px 3px rgb(0 0 0 / 25%), inset 0 0 1px #fff, inset 0 0 6px rgb(255 255 255 / 60%); transition: 0.2s; } &:active, &:focus { color: #517bab; text-shadow: 0 -1px 2px rgb(255 255 255 / 85%); border-color: #0066b4; background: linear-gradient( to bottom, rgb(194 224 248 / 100%) 0%, rgb(162 207 244 / 100%) 51%, rgb(210 232 250 / 100%) 100% ); box-shadow: 0 1px 2px rgb(0 0 0 / 20%), inset 0 0 1px #fff, inset -1px -1px 4px rgb(220 220 220 / 40%); } & .fas { margin-right: 6px; } } .button-secondary { color: #717171; border-color: #aaa; background: linear-gradient( to bottom, rgb(250 250 250 / 100%) 0%, rgb(230 230 230 / 100%) 51%, rgb(242 242 242 / 100%) 100% ); } .button-danger:hover { background: linear-gradient(to bottom, #fbf2f1 0%, #f6b4ac 51%, #fde6e3 100%); color: #f4301a; text-shadow: 0 1px rgb(255 255 255 / 50%); border-color: #f27e71; } .button-danger:active, .button-danger:focus { background: linear-gradient(to bottom, #fcd0ca 0%, #f5a69d 50%, #f9e3df 100%); color: #ce1500; text-shadow: 0 1px 1px rgb(255 255 255 / 20%), 0 -1px 1px rgb(255 255 255 / 60%); border-color: #f4301a; } .button-circle { border-radius: 50%; min-width: 28px; padding: 3px; & .fas { margin-right: 0; } } .button-floating { display: none; @media (--viewport-medium) { display: block; position: fixed; z-index: 1; bottom: 70px; } } .button-floating-top { right: 60px; } .button-floating-shortcuts { right: 110px; } /* Values List component ========================================================================== */ .values-list { } .values-list-item { margin-bottom: 3px; @media (--viewport-small) { display: flex; } } .values-list-label { display: block; font-weight: 600; @media (--viewport-small) { min-width: 130px; } } .values-list-value { } /* Server summary component ========================================================================== */ .server-summary { padding: 20px; @media (--viewport-medium) { display: flex; } } .server-summary-icon { text-align: center; margin-bottom: 10px; & .fas { font-size: 4.6rem; } @media (--viewport-medium) { margin-top: 8px; margin-bottom: 0; } } .server-summary-content { text-align: center; @media (--viewport-medium) { text-align: left; flex-grow: 1; margin-left: 30px; } @media (--viewport-large) { margin-left: 40px; } } .server-summary-title { color: #414141; margin-bottom: 10px; @media (--viewport-medium) { font-size: 1.7rem; margin-bottom: 0; } } .server-summary-list { @media (--viewport-medium) { display: flex; justify-content: space-between; } } .server-summary-item { @media (--viewport-large) { min-width: 200px; } } .server-summary-list-label { font-weight: 600; @media (--viewport-medium) { display: block; } } .server-summary-list-value { } /* Panel component ========================================================================== */ .panel { padding: 20px; border: 1px solid #d9d9d9; box-shadow: 0 1px 4px rgb(0 0 0 / 15%); border-radius: 4px; } /* Collapse component ========================================================================== */ .collapse { } .collapse[open] .collapse-header::after { transform: rotate(180deg); } .collapse-header { background: linear-gradient(to bottom, rgb(247 247 247 / 100%) 0%, rgb(255 255 255 / 100%) 100%); border: 1px solid #ddd; text-shadow: 0 1px rgb(255 255 255 / 95%); box-shadow: inset 0 0 1px rgb(255 255 255 / 100%), inset 0 0 4px rgb(255 255 255 / 80%), 0 4px 6px rgb(190 190 190 / 40%); font-weight: 600; color: #30659d; cursor: pointer; position: relative; padding: 8px 18px; &:hover { color: #ff3478; } &::after { content: ""; display: block; background-image: url("/images/arrow.svg"); background-size: 22px auto; background-repeat: no-repeat; background-position: center; size: 22px 100%; position: absolute; top: 0; right: 15px; } } .collapse-content { box-sizing: border-box; /* Work around box-sizing not inheriting in
in many browsers */ padding: 20px 20px 10px; @media (--viewport-medium) { padding: 20px 50px 10px; } } /* Login ========================================================================== */ .body-login, .body-reset { display: flex; align-items: center; justify-content: center; background: rgb(102 158 231); background: radial-gradient(circle, rgb(102 158 231 / 100%) 0%, rgb(43 86 177 / 100%) 100%); } .body-login .debug-panel, .body-reset .debug-panel { display: none; } .login { flex-grow: 1; padding: 30px; margin-bottom: 20%; & .form-label { color: #fff; } & .error { color: #be5abf; margin-bottom: 20px; } @media (--viewport-small) { border-radius: 6px; background-color: rgb(255 255 255 / 70%); box-shadow: 0 8px 25px rgb(0 0 0 / 30%), inset 0 0 2px rgb(255 255 255 / 100%); padding: 70px 50px; max-width: 370px; & .form-label { color: #4b4b4b; } } @media (--viewport-medium) { display: flex; align-items: flex-end; max-width: 500px; & form { flex-grow: 1; } } } .login-title { color: #fff; font-size: 1.05rem; font-weight: 500; margin-bottom: 30px; @media (--viewport-small) { color: #4b4b4b; } } .login-form-link { color: #fff; text-transform: uppercase; @media (--viewport-small) { color: #326b9b; &:hover { color: #0077c6; } } } /* Spinner ========================================================================== */ .spinner { -webkit-mask-box-image: radial-gradient( center, ellipse farthest-corner, rgb(0 0 0 / 100%) 68%, rgb(0 0 0 / 0%) 69.5% ); background: #eee; size: 20px; position: relative; clip-path: ellipse(10px 10px at 50% 50%); } .spinner-inner { position: absolute; top: 0; left: 0; background: transparent; border-width: 10px; size: 0; border-style: solid; border-color: transparent; border-top-color: rgb(124 124 124 / 100%); transform: rotate(-45deg); animation: inner 15s linear infinite; } .spinner-mask { position: absolute; top: 0; left: 0; background: transparent; border-width: 10px; size: 0; border-style: solid; border-color: transparent; border-top-color: #eee; transform: rotate(-45deg); animation: mask 15s linear infinite; } .spinner-mask::after, .spinner-mask-two { display: block; content: ""; opacity: 0; position: absolute; top: 0; left: 0; background: transparent; border-width: 10px; size: 0; border-style: solid; border-color: transparent; border-top-color: rgb(124 124 124 / 100%); transform: rotate(45deg); animation: mask-two 15s linear infinite; } @keyframes inner { 0% { transform: rotate(-45deg); } 25% { border-left-color: transparent; } 26% { border-left-color: rgb(124 124 124 / 100%); } 50% { border-bottom-color: transparent; } 51% { border-bottom-color: rgb(124 124 124 / 100%); } 75% { border-right-color: transparent; } 76% { border-right-color: rgb(124 124 124 / 100%); } 100% { transform: rotate(315deg); border-left-color: rgb(124 124 124 / 100%); border-bottom-color: rgb(124 124 124 / 100%); border-right-color: rgb(124 124 124 / 100%); } } @keyframes mask { 0% { transform: rotate(-45deg); } 75% { transform: rotate(-45deg); } 100% { transform: rotate(45deg); } } @keyframes mask-two { 0% { opacity: 0; } 25% { opacity: 0; } 26% { opacity: 1; } 100% { opacity: 1; } } .qr-code { border: 1px solid #cfcfcf; border-radius: 4px; box-shadow: 0 1px 4px rgb(0 0 0 / 15%); } .l-unit.selected { background-color: #f8f8f8; color: #4b4b4b; box-shadow: 0 2px 10px rgb(150 150 150 / 20%); text-shadow: 0 1px rgb(255 255 255 / 50%); border-left: 1px solid #ddd; border-right: 1px solid #ddd; & b, & strong { color: #4b4b4b; } &:hover { background-color: #fff5ce; color: #4b4b4b; box-shadow: 0 2px 14px rgb(150 150 150 / 25%); text-shadow: 0 1px rgb(255 255 255 / 60%); } } .console-output { font-family: var(--font-family-monospace); font-size: 0.92rem; color: #202020; } form#vstobjects.suspended { background-color: #fff; padding-bottom: 30px; } /* Badge component ========================================================================== */ .badge { display: inline-block; min-width: 26px; min-height: 24px; line-height: 24px; border-radius: 50%; font-weight: 700; font-size: 0.75rem; box-shadow: 0 1px 2px rgb(70 70 70 / 50%), inset 0 2px 2px #fff; color: #6c6c6c; text-shadow: 0 1px #fafafa; border: 1px solid #b8b8b8; background-color: #eaeaea; margin-top: -2px; } .l-unit--suspended .badge { background: #eaeaea; color: #c0c0c0; text-shadow: 0 -1px #fafafa; box-shadow: 0 1px 2px rgb(120 120 120 / 30%); } /* Icon component ========================================================================== */ .icon-large { font-size: 1rem; } .icon-teal { color: var(--icon-color-teal); &:hover { color: var(--icon-color-teal); } } .icon-purple { color: var(--icon-color-purple); &:hover { color: var(--icon-color-purple); } } .icon-maroon { color: var(--icon-color-maroon); &:hover { color: var(--icon-color-maroon); } } .icon-red { color: var(--icon-color-red); &:hover { color: var(--icon-color-red); } } .icon-green { color: var(--icon-color-green); &:hover { color: var(--icon-color-green); } } .icon-orange { color: var(--icon-color-orange); &:hover { color: var(--icon-color-orange); } } .icon-blue { color: var(--icon-color-blue); &:hover { color: var(--icon-color-blue); } } .icon-lightblue { color: var(--icon-color-lightblue); &:hover { color: var(--icon-color-lightblue); } } .icon-highlight { color: #323232; &:hover { color: #323232; } } .icon-dim { color: #ddd; text-shadow: 1px 1px rgb(255 255 255 / 30%); } .l-unit--suspended .icon-dim { color: #c0c0c0; } .cron-helper-container { float: right; margin-bottom: -450px; margin-top: 202px; margin-right: 70px; padding-top: 0; width: 610px; box-shadow: 0 1px 4px rgb(0 0 0 / 15%); border: 1px solid #cfcfcf; border-radius: 4px; @media (max-width: 950px) { display: none; } } .cron-helper-tabs { border: none !important; font-family: Exo, system-ui !important; & a { color: #777; font-weight: 600; line-height: 30px; padding: 0 12px; text-transform: uppercase; &:hover { color: #c36; } &:active { color: #3b9de8; } } & .form-label { padding-right: 15px; padding-left: 25px; &.first { display: inline-block; width: 120px; padding-left: 0; } } & .form-select { display: inline-block; width: 384px; } } .cron-helper-tabs .ui-tabs-selected a, .ui-tabs-tab[aria-expanded="true"] a { color: #c36; } .server-console-output { color: #c36; padding: 10px 0 20px 20px; background: #fff; } .userlist-email { font-size: 0.75rem; white-space: nowrap; text-overflow: ellipsis; } .userlist-username { margin-top: -2px; line-height: 1.2rem; } .app-footer { color: #7c7c7c; border-top: 1px solid #ddd; font-size: 0.8rem; padding-top: 20px; padding-bottom: 20px; @media (--viewport-medium) { padding-top: 40px; padding-bottom: 40px; } } .app-footer-inner { padding-left: 15px; padding-right: 15px; } /* Alerts ========================================================================== */ .alert { border-radius: 4px; border: 1px solid var(--alert-border-color); color: #fff; font-weight: 400; padding: 15px; box-shadow: var(--alert-box-shadow); text-shadow: var(--alert-text-shadow); & a { color: #fff; font-weight: bold; &:hover { text-decoration: underline; } } & .fas { flex-shrink: 0; size: 32px; font-size: 1.3rem; font-weight: 600; line-height: 30px; border-radius: 50%; text-align: center; background-color: #fff; margin-bottom: 10px; } @media (--viewport-small) { display: flex; & .fas { margin-right: 15px; margin-bottom: 0; } } } .alert-info { background-color: var(--alert-info-color); & .fas { color: var(--alert-info-color); } } .alert-danger { background-color: var(--alert-danger-color); & .fas { color: var(--alert-danger-color); } } .alert-success { background-color: var(--alert-success-color); & .fas { color: var(--alert-success-color); } } /* Inline alerts ========================================================================== */ .inline-alert { display: flex; font-weight: 600; & .fas { margin-top: 4px; margin-right: 6px; } } .inline-alert-danger { color: #f33; } .inline-alert-success { color: #53ba55; & a { color: #326b9b; &:hover { color: #c36; } &:active { color: #d53067; } } } /* Updates banner ========================================================================== */ .updates-banner { width: 100%; text-align: center; border-top: 1px solid rgb(255 255 255 / 25%); box-shadow: 0 -2px 4px rgb(0 0 0 / 40%); background-color: green; color: #fff; font-size: 0.75rem; padding: 10px; position: fixed; bottom: 0; & a { color: #fff; font-weight: 500; &:hover { color: #fff; text-decoration: underline; } } } /* Debug panel ========================================================================== */ .debug-panel { position: fixed; bottom: 0; left: 0; width: 100%; z-index: 3; box-shadow: 0 0 5px rgb(0 0 0 / 40%); @media (--viewport-medium) { width: auto; } } .debug-panel-toggle { display: block; width: 100%; border: 0; text-align: center; font-size: 0.8rem; font-weight: 500; color: #000; padding: 10px 15px; background-color: #ff0; &:hover { background-color: #ee0; } } .debug-panel-content { background-color: #eee; font-size: 0.75rem; padding: 20px; max-height: 300px; overflow: auto; }