@charset "UTF-8";
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
}

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/* Text-level semantics
   ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none;
}

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input { /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select { /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box; /* 1 */
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type=checkbox],
[type=radio] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type=search] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none;
}

/**
 * Set up a decent box model on the root element
 */
html {
  box-sizing: border-box;
}

/**
 * Make all elements from the DOM inherit from the parent box-sizing
 * Since `*` has a specificity of 0, it does not override the `html` value
 * making all elements inheriting from the root box-sizing value
 * See: https://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/
 */
*,
*::before,
*::after {
  box-sizing: inherit;
}

/**
 * Basic styles for links
 */
a {
  color: rgb(0, 0, 238);
  text-decoration: none;
}
a:hover, a:active, a:focus, a:focus-within {
  text-decoration: underline;
}

a:visited {
  color: rgb(0, 0, 238);
}

/**
 * Clear inner floats
 */
.clearfix::after {
  clear: both;
  content: "";
  display: table;
}

/**
 * Hide text while making it readable for screen readers
 * 1. Needed in WebKit-based browsers because of an implementation bug;
 *    See: https://code.google.com/p/chromium/issues/detail?id=457146
 */
.hide-text {
  overflow: hidden;
  padding: 0; /* 1 */
  text-indent: 101%;
  white-space: nowrap;
}

/**
 * Hide element while making it readable for screen readers
 * Shamelessly borrowed from HTML5Boilerplate:
 * https://github.com/h5bp/html5-boilerplate/blob/master/src/css/main.css#L119-L133
 */
.visually-hidden {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

/** Hide element
 */
.d-none {
  display: none !important;
}

/**
 * Basic typography style for copy text
 */
body {
  color: rgb(34, 34, 34);
  font: normal 100% "Open Sans", "Helvetica Neue Light", "Helvetica Neue", "Helvetica", "Arial", sans-serif;
}

@keyframes loading-blur {
  from {
    filter: blur(0.15rem);
  }
  to {
    filter: blur(0.3rem);
  }
}
@keyframes shake {
  0%, 100% {
    transform: translateX(0);
  }
  25% {
    transform: translateX(-5px);
  }
  75% {
    transform: translateX(5px);
  }
}
.grid, #acc-server-launch #checkout-block .price-display, #acc-server-launch-hp #checkout-block .price-display, #acc-server-launch #checkout-block .checkout-btn-group, #acc-server-launch-hp #checkout-block .checkout-btn-group, .session .session__header, .page-nav {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 1rem;
}
.grid > *, #acc-server-launch #checkout-block .price-display > *, #acc-server-launch-hp #checkout-block .price-display > *, #acc-server-launch #checkout-block .checkout-btn-group > *, #acc-server-launch-hp #checkout-block .checkout-btn-group > *, .session .session__header > *, .page-nav > * {
  grid-column: 1/13;
}

.subgrid {
  display: grid;
  gap: 1rem;
}
.subgrid > * {
  grid-column: 1/13;
}

.subgrid__columns {
  grid-template-columns: subgrid;
}

.subgrid__rows {
  grid-template-rows: subgrid;
}

.container {
  width: 100%;
  padding-right: 1rem;
  padding-left: 1rem;
  margin-right: auto;
  margin-left: auto;
}

@media (min-width: 1200px) {
  .container {
    max-width: 1140px;
  }
}
.content {
  margin-bottom: 1rem;
}

.header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 1rem;
  margin-bottom: 1rem;
}

.header__brand {
  display: flex;
  align-items: center;
}
.header__brand a {
  margin-right: 0.5rem;
}
.header__brand img {
  height: 1.5rem;
}

.login-controls {
  font-size: 0.875rem;
}

.page-nav {
  gap: 0.25rem;
  margin: 0.75rem 0;
}
.page-nav ol.page-nav__tabs {
  border-bottom: 1px solid rgb(245, 245, 245);
}
.page-nav h1 {
  margin: 0;
}
.page-nav .page-nav__main {
  margin: 0;
  margin-bottom: 0.5rem;
}
.page-nav .page-nav__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
}
.page-nav .page-nav__actions > :not(:last-child) {
  margin-right: 0.5rem;
}
.page-nav .page-nav__actions a:hover {
  cursor: pointer;
}

@media (min-width: 768px) {
  .page-nav .page-nav__main:has(+ .page-nav__actions) {
    grid-column: 1/8;
    margin-bottom: 0;
  }
  .page-nav .page-nav__actions {
    grid-column: 8/13;
    justify-content: flex-end;
    align-items: start;
  }
}
.acc-setting-summary {
  color: rgb(68, 68, 68);
  padding: 0.75rem;
}
.acc-setting-summary .acc-setting-summary__server-name {
  margin: 0.25rem 0;
  font-style: italic;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.acc-setting-summary .acc-setting-summary__server-name button {
  background: rgb(0, 0, 238);
  color: white;
  font-weight: 600;
  padding: 0.25rem;
}
.acc-setting-summary .acc-setting-summary__badges {
  margin: 0.25rem 0;
}
.acc-setting-summary .acc-setting-summary__badges > :not(:last-child)::after {
  content: "|";
  margin: 0 0.25rem;
}

.track-stats {
  margin-bottom: 1.5rem;
}

.server {
  border: 1px solid rgb(153, 153, 153);
}

.server__name {
  padding: 0.5rem 0.5rem 0 0.5rem;
}

.server__details {
  padding: 0 0.5rem;
}
.server__details > :not(:last-child)::after {
  content: "|";
  margin: 0 0.25rem;
}

.server__network {
  display: flex;
  flex-wrap: wrap;
  padding: 0 0.5rem 0.5rem 0.5rem;
}
.server__network > :not(:nth-child(3), :last-child)::after {
  content: "|";
  margin: 0 0.25rem;
}
.server__network span:last-child {
  display: block;
  width: 100%;
}
.server__network .btn {
  display: none;
}

.server__rt {
  display: flex;
  gap: 0.5rem;
  padding: 0.25rem 0.5rem;
  background: rgb(0, 0, 238);
  color: white;
  font-size: 0.875rem;
}
.server__rt span:last-child {
  display: none;
}

@media (min-width: 768px) {
  .server__network span:last-child {
    display: inline;
    width: auto;
    margin-left: auto;
  }
  .server__network .btn {
    display: inline-block;
  }
  .server__rt span:last-child {
    display: inline;
    margin-left: auto;
  }
}
.server-header {
  margin-bottom: 1rem;
}
.server-header .server-header__title h3 {
  margin: 0;
}
.server-header .server-header__title .btn {
  display: none;
}
.server-header .server-header__details {
  margin-bottom: 1rem;
}
.server-header .server-header__details > :not(:last-child)::after {
  content: "|";
  margin: 0 0.25rem;
}

@media (min-width: 768px) {
  .server-header .server-header__title {
    display: flex;
    justify-content: space-between;
  }
  .server-header .server-header__title h3 {
    max-width: 85%;
  }
  .server-header .server-header__title .btn {
    display: inline-block;
  }
}
.list, .server-sessions-list {
  padding: 0;
}
.list li, .server-sessions-list li {
  list-style: none;
  padding: 0.5rem;
  border-bottom: 1px solid rgb(153, 153, 153);
}

.server-sessions-list li {
  font-size: 0.85rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.server-sessions-list li div:first-child {
  margin-right: 0.5rem;
}
.server-sessions-list li .session-extra {
  display: none;
}
.server-sessions-list li.server-sessions-list__load-more {
  justify-content: space-around;
  border-bottom: 0;
  padding: 1.75rem 0.5rem;
}

@media (min-width: 768px) {
  .server-sessions-list li {
    font-size: 1rem;
    flex-wrap: no-wrap;
  }
  .server-sessions-list li .session-extra {
    display: inline;
  }
}
.session .session__header fieldset ul {
  padding-left: 1.25rem;
}
.session .session__header h2 {
  font-style: italic;
  margin-bottom: 0;
}
.session .session__header .session__header__info {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 600;
}
.session .table .invalid-lap {
  color: gray;
}
.session .table .valid-lap {
  font-weight: 700;
}
.session .table .green {
  color: rgb(40, 210, 60);
  font-weight: 700;
}
.session .table .purple {
  color: rgb(173, 55, 220);
  font-weight: 700;
}

@media (min-width: 768px) {
  .session .session__header div {
    grid-column: 1/10;
  }
  .session .session__header fieldset {
    grid-column: 10/13;
  }
}
.btn {
  display: inline-block;
  padding: 0.5rem;
  text-decoration: none;
  background-color: rgb(245, 245, 245);
}
.btn:hover {
  cursor: pointer;
}

.btn__txt {
  background-color: unset;
  padding: 0;
}
.btn__txt::before {
  display: inline-block;
  margin-right: 0.25rem;
  color: rgb(34, 34, 34);
  content: "[";
}
.btn__txt::after {
  display: inline-block;
  margin-left: 0.25rem;
  color: rgb(34, 34, 34);
  content: "]";
}

.btn__brand {
  background-color: rgb(0, 0, 238);
  color: #fff;
}
.btn__brand:active, .btn__brand:focus, .btn__brand:hover, .btn__brand:visited {
  color: #fff;
}

.btn--small {
  font-size: 0.875rem;
  padding: 0.25rem 0.375rem;
}

.chevron-bullets {
  padding-left: 1rem;
}
.chevron-bullets li::marker {
  content: "»";
  font-size: 1.5rem;
  color: rgb(0, 0, 238);
}
.chevron-bullets li {
  padding-left: 0.5rem;
}

.crumbs {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  margin: 0;
  padding: 0;
}

.crumbs__item + .crumbs__item {
  padding-left: 0.5rem;
}
.crumbs__item + .crumbs__item::before {
  content: "/";
  padding-right: 0.5rem;
  float: left;
}

.form-ctrl {
  display: block;
  width: 100%;
}

.form-ctrl-group {
  display: flex;
  align-items: center;
}
.form-ctrl-group .form-ctrl-group__text {
  background: rgb(245, 245, 245);
  padding: 0.2rem;
  margin-right: 0.2rem;
}

.form-ctrl.form-ctrl__checkbox {
  display: inline;
  width: auto;
}

.form-label {
  display: inline-block;
  margin-bottom: 0.5rem;
}
.form-label:has(+ .form-ctrl.invalid), .form-label:has(+ .form-ctrl-group .form-ctrl.invalid) {
  color: rgb(255, 0, 0);
}

.form-ctrl-group:has(.form-ctrl.invalid) ~ .form-reason, .form-ctrl.invalid ~ .form-reason {
  display: block;
}

.form-reason {
  display: none;
  color: rgb(255, 0, 0);
  padding-left: 1rem;
}

.form-reason.invalid {
  display: block;
}

.form-text {
  display: block;
  margin: 0.5rem 0;
}

.fieldset__strong {
  border: 4px double rgb(153, 153, 153);
  margin-bottom: 1.5rem;
}
.fieldset__strong legend {
  font-weight: 600;
  color: #fff;
  background: rgb(34, 34, 34);
  padding: 0.25rem 0.5rem;
}

.form-actions {
  display: flex;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
}
.form-actions div {
  flex: 0 0 100%;
}
.form-actions button {
  width: 100%;
  margin-bottom: 0.5rem;
}

@media (min-width: 768px) {
  .form-actions {
    justify-content: space-between;
    flex-wrap: nowrap;
  }
  .form-actions div {
    flex: 0 0 auto;
  }
  .form-actions button {
    width: auto;
    margin-bottom: 0;
  }
}
i.icon {
  font-style: unset;
  cursor: pointer;
}

.light {
  display: inline-block;
  border-radius: 50%;
  width: 0.75rem;
  height: 0.75rem;
  background-color: #000;
  border: 1px solid #000;
}

.light--green {
  background-color: rgb(0, 255, 0);
  border-color: rgb(0, 255, 0);
}

.light--red {
  background-color: rgb(255, 0, 0);
  border-color: rgb(255, 0, 0);
}

.light--yellow {
  background-color: rgb(255, 255, 0);
  border-color: rgb(255, 255, 0);
}

.msgs .msg {
  border-width: 1px;
  border-style: solid;
  padding: 0.875rem;
}
.msgs .msg.msg--info {
  color: rgb(10, 30, 180);
  border-color: rgb(10, 30, 180);
  background-color: rgba(130, 150, 255, 0.5);
}
.msgs .msg.msg--success {
  color: rgb(10, 140, 30);
  border-color: rgb(10, 140, 30);
  background-color: rgba(130, 255, 150, 0.5);
}
.msgs .msg.msg--warning {
  color: rgb(255, 170, 20);
  border-color: rgb(255, 170, 20);
  background-color: rgba(255, 230, 150, 0.5);
}
.msgs .msg.msg--failure {
  color: rgb(180, 10, 30);
  border-color: rgb(180, 10, 30);
  background-color: rgba(255, 130, 150, 0.5);
}

.table-wrap {
  overflow-x: auto;
}

.table {
  width: 100%;
  border-collapse: collapse;
}
.table th {
  text-align: start;
}
.table > :not(caption) > * > * {
  padding: 0.375rem 0.375rem;
  border-bottom: rgb(153, 153, 153) thin solid;
}
.table tfoot td {
  font-weight: 700;
}

ol.tabs {
  display: flex;
  gap: 0 1rem;
  flex-wrap: wrap;
  margin-top: 0;
  padding-left: 0;
  list-style: none;
}
ol.tabs li {
  padding: 0.25rem;
}
ol.tabs li a:hover {
  text-decoration: none;
}
ol.tabs li.active {
  border-bottom: rgb(0, 0, 238) 2px solid;
}
ol.tabs li.disabled {
  color: rgb(153, 153, 153);
  cursor: not-allowed;
}
ol.tabs li.disabled a {
  color: rgb(153, 153, 153);
}

#home #racehub-aside {
  order: 2;
}
#home #racehub-aside .btn {
  width: 100%;
  margin-bottom: 0.5rem;
}
#home #racehub-main {
  order: 1;
}
#home #racehub-main h3 {
  margin: 0;
}
#home #racehub-main .chevron-bullets {
  margin-top: 0;
}
#home #racehub-main .chevron-bullets .btn {
  width: 100%;
}
#home #racehub-main #acc-logo img {
  width: 100%;
}

@media (min-width: 768px) {
  #home .grid {
    column-gap: 2.5rem;
  }
  #home #racehub-aside {
    order: 1;
    grid-column: 1/4;
  }
  #home #racehub-main {
    order: 2;
    grid-column: 4/13;
    row-gap: 0;
  }
  #home #racehub-main .chevron-bullets .btn {
    width: auto;
  }
  #home #racehub-main #acc-logo img {
    width: 60%;
  }
  #home #racehub-main #acc-server-links {
    grid-column: 1/5;
  }
  #home #racehub-main #acc-settings-links {
    grid-column: 5/9;
  }
}
#create-profile .profile-form > div, #edit-profile .profile-form > div {
  margin-bottom: 1rem;
}

@media (min-width: 768px) {
  #create-profile #user-info, #create-profile .profile-form, #edit-profile #user-info, #edit-profile .profile-form {
    grid-column: 1/10;
  }
}
#stats-track .track-laps-group {
  border: 1px solid rgb(68, 68, 68);
  padding: 2rem;
  margin-bottom: 1.5rem;
  row-gap: 0.75rem;
}
#stats-track .track-laps-group h2 {
  margin: 0;
}

@media (min-width: 768px) {
  #stats-track .track-laps-group .track-laps-group__stats-table {
    grid-column: 1/6;
  }
  #stats-track .track-laps-group .track-laps-group__top-cars {
    grid-column: 8/13;
  }
}
#acc-home h3 {
  margin: 0;
}
#acc-home .chevron-bullets {
  margin-top: 0;
}
#acc-home .chevron-bullets .btn {
  width: 100%;
}
#acc-home #acc-logo img {
  width: 100%;
}

@media (min-width: 768px) {
  #acc-home .grid {
    gap: 0;
  }
  #acc-home .chevron-bullets .btn {
    width: auto;
  }
  #acc-home #acc-logo img {
    width: 40%;
  }
  #acc-home #acc-server-links {
    grid-column: 1/5;
  }
  #acc-home #acc-settings-links {
    grid-column: 5/9;
  }
}
#acc-create-bop #bop-json-group {
  margin-bottom: 1rem;
}

@media (min-width: 768px) {
  #acc-create-bop #acc-server-bop-name-group {
    grid-column: 1/8;
    margin-bottom: 1rem;
  }
  #acc-create-bop #auto-suffix-group {
    grid-column: 8/13;
    margin-bottom: 1rem;
  }
}
#acc-bops-index .list li {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

#acc-entry-edit h2 {
  margin-bottom: 0;
  text-decoration: underline;
  margin-bottom: 0;
}
#acc-entry-edit .header-subtitle {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 600;
}

.entry-form hr {
  margin: 2rem 0;
}
.entry-form .entry-controls {
  margin: 1.5rem 0;
}

@media (min-width: 768px) {
  .entry-form .driver__player-id-group {
    grid-column: 1/7;
  }
  .entry-form .driver__category-group {
    grid-column: 7/13;
  }
  .entry-form .driver__first-name-group {
    grid-column: 1/6;
    align-self: last baseline;
  }
  .entry-form .driver__last-name-group {
    grid-column: 6/11;
    align-self: last baseline;
  }
  .entry-form .driver__short-name-group {
    grid-column: 11/13;
  }
  .entry-form .entry__race-number-group {
    grid-column: 1/7;
  }
  .entry-form .entry__forced-car-model-group {
    grid-column: 7/13;
  }
  .entry-form .entry__default-grid-position-group {
    grid-column: 1/7;
  }
  .entry-form .entry__ballast-kg-group {
    grid-column: 7/10;
  }
  .entry-form .entry__restrictor-group {
    grid-column: 10/13;
  }
  .entry-form .entry__override-driver-info-group {
    grid-column: 1/7;
  }
  .entry-form .entry__is-server-admin-group {
    grid-column: 7/13;
  }
}
#acc-entry-list form fieldset {
  padding: 1rem;
}
#acc-entry-list #entries-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#acc-entry-list .entry {
  padding: 1rem;
  background: rgb(245, 245, 245);
}
#acc-entry-list .entry__body__drivers, #acc-entry-list .entry__body__other {
  padding-top: 0.5rem;
}
#acc-entry-list .entry__body__drivers p, #acc-entry-list .entry__body__other p {
  margin: 0;
}
#acc-entry-list #controls {
  margin-bottom: 0.5rem;
}
#acc-entry-list #controls button {
  width: 100%;
  margin-bottom: 0.5rem;
}

@media (min-width: 768px) {
  #acc-entry-list form fieldset div:first-of-type {
    grid-column: 1/8;
  }
  #acc-entry-list .entry__header {
    display: flex;
  }
  #acc-entry-list .entry__header__name {
    flex-grow: 1;
  }
  #acc-entry-list .entry__body {
    display: flex;
    justify-content: space-between;
    align-items: last baseline;
  }
  #acc-entry-list #controls button {
    width: auto;
    margin-bottom: 0;
  }
}
#acc-entry-create h2 {
  font-style: italic;
  text-decoration: underline;
  margin-bottom: 0;
}
#acc-entry-create .header-subtitle {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 600;
}

#acc-server-settings-edit h2 {
  margin: 0;
}
#acc-server-settings-edit .acc-setting-summary {
  background: rgb(245, 245, 245);
}
#acc-server-settings-edit #instructions {
  margin-bottom: 1.5rem;
}
#acc-server-settings-edit #instructions h3 {
  font-size: 1.25rem;
}
#acc-server-settings-edit #instructions #summary-group {
  box-shadow: 0.125rem 0.125rem 0.25rem rgb(153, 153, 153);
}
#acc-server-settings-edit #instructions #summary-group.htmx-request, #acc-server-settings-edit #instructions #summary-group.htmx-swapping {
  animation: loading-blur 200ms ease-in-out infinite alternate, shake 200ms ease-in-out;
}
#acc-server-settings-edit #toc h4 {
  margin-top: 0;
}
#acc-server-settings-edit #acc-server-edit-form fieldset {
  padding: 1rem;
  margin-bottom: 1.5rem;
}
#acc-server-settings-edit #acc-server-edit-form fieldset legend {
  font-size: 1.25rem;
  font-weight: 700;
}
#acc-server-settings-edit #acc-server-edit-form .danger {
  color: rgb(180, 10, 30);
}
#acc-server-settings-edit #acc-server-edit-form .rules__disabled-message {
  padding: 0.25rem;
  color: rgb(153, 153, 153);
  font-style: italic;
}
#acc-server-settings-edit #acc-server-edit-form .rules__disabled-message::before {
  content: "These rules do not apply for ACC public multiplayer servers. Password protect the server to edit them.";
}
#acc-server-settings-edit #acc-server-edit-form #event-sessions .event-session {
  margin-bottom: 1rem;
  padding-top: 1rem;
  border-top: 1px solid;
}
#acc-server-settings-edit #acc-server-edit-form #event-sessions .event-session > * {
  grid-column: span 6;
}
#acc-server-settings-edit #acc-server-edit-form #controls-group {
  display: flex;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
}
#acc-server-settings-edit #acc-server-edit-form #controls-group div {
  flex: 0 0 100%;
}
#acc-server-settings-edit #acc-server-edit-form #controls-group button {
  width: 100%;
  margin-bottom: 0.5rem;
}

@media (min-width: 768px) {
  #acc-server-settings-edit #instructions {
    grid-column: 1/10;
  }
  #acc-server-settings-edit #toc {
    grid-column: 10/13;
    display: flex;
    justify-content: end;
  }
  #acc-server-settings-edit #acc-server-edit-form #acc-server-setting-name-group {
    grid-column: 1/7;
  }
  #acc-server-settings-edit #acc-server-edit-form #server-name-group {
    grid-column: 7/13;
  }
  #acc-server-settings-edit #acc-server-edit-form #admin-password-group {
    grid-column: 1/5;
  }
  #acc-server-settings-edit #acc-server-edit-form #password-group {
    grid-column: 5/9;
  }
  #acc-server-settings-edit #acc-server-edit-form #spectator-password-group {
    grid-column: 9/13;
  }
  #acc-server-settings-edit #acc-server-edit-form #car-group-group {
    grid-column: 1/5;
  }
  #acc-server-settings-edit #acc-server-edit-form #max-car-slots-group {
    grid-column: 5/9;
  }
  #acc-server-settings-edit #acc-server-edit-form #formation-lap-type-group {
    grid-column: 9/13;
  }
  #acc-server-settings-edit #acc-server-edit-form #track-medals-group {
    grid-column: 1/5;
  }
  #acc-server-settings-edit #acc-server-edit-form #racecraft-rating-group {
    grid-column: 5/9;
  }
  #acc-server-settings-edit #acc-server-edit-form #safety-rating-group {
    grid-column: 9/13;
  }
  #acc-server-settings-edit #acc-server-edit-form #randomize-track-when-empty-group {
    grid-column: 1/5;
  }
  #acc-server-settings-edit #acc-server-edit-form #is-race-locked-group {
    grid-column: 5/9;
  }
  #acc-server-settings-edit #acc-server-edit-form #short-formation-lap-group {
    grid-column: 9/13;
  }
  #acc-server-settings-edit #acc-server-edit-form #ambient-temp-group, #acc-server-settings-edit #acc-server-edit-form #pre-race-waiting-time-seconds-group {
    grid-column: 1/4;
  }
  #acc-server-settings-edit #acc-server-edit-form #cloud-level-group, #acc-server-settings-edit #acc-server-edit-form #session-over-time-seconds-group {
    grid-column: 4/7;
  }
  #acc-server-settings-edit #acc-server-edit-form #rain-group, #acc-server-settings-edit #acc-server-edit-form #post-qualy-seconds-group {
    grid-column: 7/10;
  }
  #acc-server-settings-edit #acc-server-edit-form #weather-randomness-group, #acc-server-settings-edit #acc-server-edit-form #post-race-seconds-group {
    grid-column: 10/13;
  }
  #acc-server-settings-edit #acc-server-edit-form #event-sessions .event-session {
    padding-top: 0;
    border-top: none;
  }
  #acc-server-settings-edit #acc-server-edit-form #event-sessions .session-type-group {
    grid-column: 1/3;
  }
  #acc-server-settings-edit #acc-server-edit-form #event-sessions .day-of-weekend-group {
    grid-column: 3/5;
  }
  #acc-server-settings-edit #acc-server-edit-form #event-sessions .hour-of-day-group {
    grid-column: 5/7;
  }
  #acc-server-settings-edit #acc-server-edit-form #event-sessions .session-duration-minutes-group {
    grid-column: 7/10;
  }
  #acc-server-settings-edit #acc-server-edit-form #event-sessions .time-multiplier-group {
    grid-column: 10/13;
  }
  #acc-server-settings-edit #acc-server-edit-form #entry-list-group {
    grid-column: 1/7;
  }
  #acc-server-settings-edit #acc-server-edit-form #bop-group {
    grid-column: 7/13;
  }
  #acc-server-settings-edit #acc-server-edit-form .rules__fields {
    align-items: flex-end;
  }
  #acc-server-settings-edit #acc-server-edit-form .rules__fields > * {
    grid-column: span 4;
  }
  #acc-server-settings-edit #acc-server-edit-form #controls-group {
    justify-content: space-between;
    flex-wrap: nowrap;
  }
  #acc-server-settings-edit #acc-server-edit-form #controls-group div {
    flex: 0 0 auto;
  }
  #acc-server-settings-edit #acc-server-edit-form #controls-group button {
    width: auto;
    margin-bottom: 0;
  }
}
#acc-server-settings-index .server-setting {
  background: rgb(245, 245, 245);
}
#acc-server-settings-index .server-setting__controls {
  padding: 0.75rem 0.75rem 0 0.75rem;
}
#acc-server-settings-index .server-setting__controls__name {
  margin: 0;
}
#acc-server-settings-index .server-setting__controls__actions {
  margin: 0;
}
#acc-server-settings-index .server-setting__servers {
  padding: 0 0.75rem 0.75rem 0.75rem;
}
#acc-server-settings-index .server-setting__servers .may-need-restart {
  cursor: help;
}

@media (min-width: 768px) {
  #acc-server-settings-index .server-setting__controls {
    display: flex;
  }
  #acc-server-settings-index .server-setting__controls__name {
    flex-grow: 1;
  }
}
#acc-create-server-setting-quick #create-acc-server-quick-form h2 {
  margin: 0;
}
#acc-create-server-setting-quick #create-acc-server-quick-form .weather-container .weather-label-container .form-label {
  display: block;
}
#acc-create-server-setting-quick #create-acc-server-quick-form .weather-container:has(> .form-reason.invalid) .form-label {
  color: rgb(255, 0, 0);
}
#acc-create-server-setting-quick #create-acc-server-quick-form .weather-container:has(> .form-reason.invalid) fieldset {
  border-color: rgb(255, 0, 0);
}
#acc-create-server-setting-quick #create-acc-server-quick-form .submission-container button {
  display: block;
  width: 100%;
  margin-bottom: 0.5rem;
}

@media (min-width: 768px) {
  #acc-create-server-setting-quick #create-acc-server-quick-form .track-container {
    grid-column: 1/5;
  }
  #acc-create-server-setting-quick #create-acc-server-quick-form .weekend-structure-container {
    grid-column: 5/9;
  }
  #acc-create-server-setting-quick #create-acc-server-quick-form .session-duration-container {
    grid-column: 9/13;
  }
  #acc-create-server-setting-quick #create-acc-server-quick-form .weather-container .static-weather-container {
    grid-column: 1/7;
  }
  #acc-create-server-setting-quick #create-acc-server-quick-form .weather-container .static-weather-container fieldset {
    height: 100%;
  }
  #acc-create-server-setting-quick #create-acc-server-quick-form .weather-container .dynamic-weather-container {
    grid-column: 7/13;
  }
  #acc-create-server-setting-quick #create-acc-server-quick-form .weather-container .dynamic-weather-container fieldset {
    height: 100%;
  }
  #acc-create-server-setting-quick #create-acc-server-quick-form .submission-container button {
    display: inline-block;
    width: auto;
  }
}
#my-acc-servers-index .btn {
  width: 100%;
  text-align: center;
}

@media (min-width: 768px) {
  #my-acc-servers-index .btn {
    font-size: 0.875rem;
    padding: 0.25rem 0.375rem;
    width: auto;
    text-align: left;
  }
}
#acc-servers-index .btn {
  width: 100%;
  text-align: center;
}
#acc-servers-index #search-panel {
  margin-bottom: 1rem;
}
#acc-servers-index #search-ctrl input {
  width: 100%;
  padding: 0.25rem;
}
#acc-servers-index #vis-ctrl {
  grid-column: 1/7;
  display: flex;
  gap: 0.5rem;
  align-items: center;
}
#acc-servers-index #status {
  grid-column: 7/13;
  display: flex;
  gap: 0.2rem;
  justify-content: flex-end;
  align-items: center;
}
#acc-servers-index #status a {
  text-decoration: underline;
}

@media (min-width: 768px) {
  #acc-servers-index .btn {
    font-size: 0.875rem;
    padding: 0.25rem 0.375rem;
    width: auto;
    text-align: left;
  }
  #acc-servers-index #search-ctrl {
    grid-column: 1/9;
  }
  #acc-servers-index #vis-ctrl {
    grid-column: 9/11;
  }
  #acc-servers-index #status {
    grid-column: 11/13;
  }
}
#acc-server-detail .grid {
  gap: 0.5rem;
}
#acc-server-detail #server-controls fieldset {
  border: 3px solid rgb(0, 0, 238);
}
#acc-server-detail #server-controls legend {
  font-weight: 700;
}
#acc-server-detail #server-controls button {
  width: 100%;
}
#acc-server-detail #server-controls p.setting-name {
  margin-top: 0;
}
#acc-server-detail #server-controls p.restart {
  text-align: center;
}
#acc-server-detail #server-controls p:last-child select {
  margin-bottom: 1rem;
}
#acc-server-detail .server-content_rt {
  border: 1px solid rgb(245, 245, 245);
}
#acc-server-detail .server-content_rt h4 {
  margin: 0;
  margin-bottom: 0.5rem;
  padding: 0.25rem;
  background-color: rgb(245, 245, 245);
}
#acc-server-detail .server-content_rt h5 {
  margin: 0;
  padding: 0 0.25rem;
}
#acc-server-detail .server-content_rt__network, #acc-server-detail .server-content_rt__rental {
  font-size: 0.875rem;
  padding: 0 0.25rem;
  margin-bottom: 1rem;
}

@media (min-width: 768px) {
  #acc-server-detail #server-content {
    grid-column: 1/10;
    order: 1;
  }
  #acc-server-detail #server-controls {
    grid-column: 10/13;
    order: 2;
  }
  #acc-server-detail .server-content_rt__network, #acc-server-detail .server-content__rt__rental {
    display: flex;
    flex-wrap: wrap;
  }
  #acc-server-detail .server-content_rt__network > :not(:last-child)::after, #acc-server-detail .server-content__rt__rental > :not(:last-child)::after {
    content: "|";
    margin: 0 0.25rem;
  }
}
#acc-server-launch .grid, #acc-server-launch #checkout-block .checkout-btn-group, #acc-server-launch #checkout-block .price-display, #acc-server-launch-hp .grid, #acc-server-launch-hp #checkout-block .checkout-btn-group, #acc-server-launch-hp #checkout-block .price-display {
  row-gap: 0.5rem;
}
#acc-server-launch h2, #acc-server-launch-hp h2 {
  margin: 0;
}
#acc-server-launch #standard-btn, #acc-server-launch #hp-btn, #acc-server-launch-hp #standard-btn, #acc-server-launch-hp #hp-btn {
  font-weight: 700;
}
#acc-server-launch #standard-btn, #acc-server-launch-hp #standard-btn {
  grid-column: 1/7;
  font-weight: 700;
}
#acc-server-launch #hp-btn, #acc-server-launch-hp #hp-btn {
  grid-column: 7/13;
  font-weight: 700;
}
#acc-server-launch #sales-pitch-block, #acc-server-launch-hp #sales-pitch-block {
  margin: 1rem 0;
}
#acc-server-launch #plans-block p, #acc-server-launch-hp #plans-block p {
  margin: 0.5rem 0;
}
#acc-server-launch .promo, #acc-server-launch-hp .promo {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  font-weight: 700;
  color: rgb(68, 68, 68);
}
#acc-server-launch .promo .promo__highlight, #acc-server-launch-hp .promo .promo__highlight {
  font-size: 1.75rem;
  background-image: linear-gradient(to right, rgb(0, 0, 238), rgb(180, 180, 255));
  border-bottom: 5px solid transparent;
  border-image: linear-gradient(to left, fuchsia, rgb(255, 209, 255)) 1;
  color: transparent;
  background-clip: text;
}
#acc-server-launch #checkout-block, #acc-server-launch-hp #checkout-block {
  background-color: rgb(0, 0, 238);
  color: white;
  margin-bottom: 1rem;
  box-shadow: 0.25rem 0.25rem 0.25rem rgb(153, 153, 153);
}
#acc-server-launch #checkout-block .price-display, #acc-server-launch-hp #checkout-block .price-display {
  align-items: center;
  gap: 0.25rem;
}
#acc-server-launch #checkout-block .price-display .price-display__pitch p, #acc-server-launch-hp #checkout-block .price-display .price-display__pitch p {
  padding: 0 1rem;
}
#acc-server-launch #checkout-block .price-display .price-display__price p, #acc-server-launch-hp #checkout-block .price-display .price-display__price p {
  text-align: center;
  font-weight: 700;
}
#acc-server-launch #checkout-block .price-display .price-display__price p:first-child, #acc-server-launch-hp #checkout-block .price-display .price-display__price p:first-child {
  margin: 0.875rem 0 0 0;
  font-size: 2rem;
}
#acc-server-launch #checkout-block .price-display .price-display__price p:last-child, #acc-server-launch-hp #checkout-block .price-display .price-display__price p:last-child {
  font-size: 1.25rem;
  line-height: 1rem;
  margin: 0 0 0.875rem 0;
}
#acc-server-launch #checkout-block .price-display.htmx-request, #acc-server-launch #checkout-block .price-display.htmx-swapping, #acc-server-launch-hp #checkout-block .price-display.htmx-request, #acc-server-launch-hp #checkout-block .price-display.htmx-swapping {
  animation: loading-blur 200ms ease-in-out infinite alternate, shake 200ms ease-in-out;
}
#acc-server-launch #checkout-block .checkout-btn-group, #acc-server-launch-hp #checkout-block .checkout-btn-group {
  gap: 0.25rem;
  margin-bottom: 1rem;
}
#acc-server-launch #checkout-block .checkout-btn-group button, #acc-server-launch-hp #checkout-block .checkout-btn-group button {
  grid-column: 3/11;
  font-size: 1.25rem;
}
#acc-server-launch #checkout-block .checkout-btn-group small, #acc-server-launch-hp #checkout-block .checkout-btn-group small {
  grid-column: 3/11;
  text-align: center;
}
#acc-server-launch #checkout-block .checkout-btn-group small a, #acc-server-launch-hp #checkout-block .checkout-btn-group small a {
  color: #fff;
  text-decoration: underline;
}

@media (min-width: 768px) {
  #acc-server-launch #standard-btn, #acc-server-launch #hp-btn, #acc-server-launch-hp #standard-btn, #acc-server-launch-hp #hp-btn {
    font-size: 1.5rem;
  }
  #acc-server-launch #acc-server-setting-block, #acc-server-launch-hp #acc-server-setting-block {
    grid-column: 1/7;
  }
  #acc-server-launch #regions-block, #acc-server-launch-hp #regions-block {
    grid-column: 7/13;
  }
  #acc-server-launch #checkout-block .price-display .price-display__pitch, #acc-server-launch-hp #checkout-block .price-display .price-display__pitch {
    grid-column: 3/8;
  }
  #acc-server-launch #checkout-block .price-display .price-display__pitch p, #acc-server-launch-hp #checkout-block .price-display .price-display__pitch p {
    padding: 0;
  }
  #acc-server-launch #checkout-block .price-display .price-display__price, #acc-server-launch-hp #checkout-block .price-display .price-display__price {
    grid-column: 8/11;
  }
  #acc-server-launch-hp #plans-block {
    grid-column: 1/7;
  }
  #acc-server-launch-hp #instance-size-block {
    grid-column: 7/13;
  }
}
.acc-session-analysis .session-analysis__tabs {
  display: none;
  margin: 1.125rem 0;
}
.acc-session-analysis .fast {
  color: red;
}
.acc-session-analysis .slow {
  color: blue;
}

#acc-session-home .session-results-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

@media (min-width: 768px) {
  #acc-driver-profile #driver-info {
    grid-column: 1/6;
  }
  #acc-driver-profile #recent-sessions {
    grid-column: 6/13;
  }
}

/*# sourceMappingURL=main.css.map */
