body {
    background: var(--background-color);
    color: var(--text-color);
    margin: 0;
    font-family: -apple-system, BlinkMacSystemFont, Segoe UI Variable, Segoe UI, Roboto, Helvetica Neue, Helvetica, Arial, sans-serif;
    font-size: 16px;
    line-height: 1.5
}

thead th {
    vertical-align: bottom;
    padding-top: 0;
}

th,
td {
    border-left: 1px solid var(--border-color);
    text-align: left;
    padding: .25em .5em;
    padding-top: 0.25em;
}

.compact td {
    vertical-align: top;
}

.table-wrapper table {
    border-collapse: separate;
    border-spacing: 0;
    white-space: nowrap;
}

td {
    border-top: 1px solid var(--border-color);
}

time,
.tabular,
#fare-table td,
.aside td,
.trip-timetable td {
    font-variant-numeric: tabular-nums;
}



.skip {
    text-align: center;
    height: 0;
    display: block;
    overflow: hidden
}

.skip:focus {
    height: auto
}

code {
    font-family: ui-monospace, Monaco, Consolas, monospace;
    font-size: .875em
}

header,
main,
footer {
    display: block
}

.wide .site-header div {
  width: 60.5em;
  max-width: 100vw;
}

main {
    margin: 0 auto;
    padding: 0 1em
}

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

a:hover,
a:focus {
    text-decoration-skip-ink: auto;
    text-decoration: underline
}

a:active {
    background-color: var(--brand-color);
    color: var(--active-link-color)
}

label {
    cursor: pointer
}

#id_features {
    margin-top: -.5em
}

#id_reg,
#id_previous_reg {
    text-transform: uppercase
}

.site-header {
    background: var(--brand-color);
    position: relative;
    overflow: hidden
}

.site-header a {
    color: var(--header-text-color);
    padding: .66667em;
    line-height: 1;
    display: inline-block
}

.site-header a:hover {
    background-color: var(--brand-color-darker);
    text-decoration: none
}

.site-header .site-name {
    font-size: 1.5em
}

.site-header div {
    margin: 0 auto
}

.site-header div .site-name {
    position: absolute
}

.site-header ul {
    float: right;
    margin: 0
}

.site-header ul li {
    display: inline
}

.site-header ul a {
    padding: 1em 1em 1em .5em;
    line-height: 1.5em
}

.site-header .search {
    float: right
}

.site-header .search label {
    padding: 1em 1em 1em 0;
    line-height: 1.5;
    display: block
}

.site-header .search label input {
    z-index: 1;
    border-radius: 0;
    margin: 0;
    position: absolute;
    top: -3em
}

.site-header .search label input:focus {
    border-width: .75em 1em;
    width: 100%;
    top: 0;
    left: 0
}

.site-header .search label+input {
    display: none
}

.site-header ul+.search label {
    padding-right: .5em
}

.search input[type=search] {
    flex-grow: 1;
    margin-right: .5em
}

h1 {
    margin: .5em 0;
    line-height: 1.2em
}

h1 {
    font-size: 1.75em
}

.button,
input[type=submit] {
    -webkit-appearance: none;
    appearance: none;
    background: var(--brand-color);
    border: 0;
    border-bottom: .0625em solid var(--brand-color-darker);
    color: inherit;
    font: inherit;
    border-radius: .5em;
    margin-bottom: .0625em;
    padding: .25em .5em;
    display: inline-block;
    position: relative;
    top: .0625em
}

.button:hover,
input[type=submit]:hover {
    border-bottom-width: .125em;
    margin-bottom: 0;
    text-decoration: none;
    top: 0
}

.button:focus,
.button:active,
input[type=submit]:focus,
input[type=submit]:active {
    background-color: var(--brand-color-darker);
    border-bottom: 0;
    margin-bottom: .125em;
    top: .0625em
}

input[type=text],
input[type=email],
input[type=password],
textarea {
    width: 100%;
    display: block
}

input[type=number],
input[type=text],
input[type=time],
input[type=email],
input[type=search],
input[type=datetime-local],
input[type=password],
textarea {
    -webkit-appearance: none;
    appearance: none;
    background: var(--background-color);
    border: 1px solid var(--border-color);
    box-sizing: border-box;
    color: inherit;
    font: inherit;
    border-radius: .5em;
    outline: 0;
    padding: .25em .5em
}

/* The container */
.container {
    background: var(--background-color);
    display: block;
    position: relative;
    padding-left: 25px;
    margin-bottom: 12px;
    cursor: pointer;
    font-size: inherit;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

/* Hide the browser's default checkbox */
.container input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0;
}

/* Create a custom checkbox */
.checkmark {
    position: absolute;
    top: 0;
    left: 0;
    height: 20px;
    width: 20px;
    background-color: var(--background-color);
    margin-top: 2px;
    border-radius: .25em;
    border: solid 1px var(--border-color);
}

/* On mouse-over, add a grey background color */
.container:hover input~.checkmark {
    background-color: var(--border-color-darker);
}

/* When the checkbox is checked, add a blue background */
.container input:checked~.checkmark {
    background-color: #2196F3;
}

/* Create the checkmark/indicator (hidden when not checked) */
.checkmark:after {
    content: "";
    position: absolute;
    display: none;
}

/* Show the checkmark when checked */
.container input:checked~.checkmark:after {
    display: block;
}

/* Style the checkmark/indicator */
.container .checkmark:after {
    left: 6px;
    top: 2px;
    width: 5px;
    height: 10px;
    border: solid white;
    border-width: 0 3px 3px 0;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

input[type=text]:focus,
input[type=url]:focus,
input[type=number]:focus,
input[type=email]:focus,
input[type=password]:focus,
input[type=search]:focus,
input[type=date]:focus,
input[type=time]:focus,
input[type=number]:focus,
input[type=datetime-local]:focus,
textarea:focus {
    border-color: var(--border-color-darker)
}

::-webkit-datetime-edit {
    padding: 0
}

::-webkit-calendar-picker-indicator {
    margin-left: 0
}

select {
    -webkit-appearance: none;
    appearance: none;
    background-color: var(--background-color);
    border: 1px solid var(--border-color);
    color: inherit;
    font: inherit;
    background-image: url(data:image/svg+xml;charset=utf8,%3Csvg\ viewBox=\'0\ 0\ 16\ 8\'\ width=\'16\'\ height=\'8\'\ xmlns=\'http://www.w3.org/2000/svg\'%3E%3Cpolygon\ points=\'0,0\ 4,8\ 8,0\'/%3E%3C/svg%3E);
    background-position: 100%;
    background-repeat: no-repeat;
    border-radius: .5em;
    max-width: 100%;
    padding: .25em 1.5em .25em .25em
}

form p select {
    box-sizing: border-box;
    width: 100%;
    display: block
}

.helptext {
    font-size: .875em;
    display: block
}

input[type=search]::-webkit-search-decoration {
    -webkit-appearance: none
}

ul,
ol,
li {
    padding: 0;
    list-style: none
}

main li {
    break-inside: avoid
}

main li>a {
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden
}

main p a {
    padding: 0;
    display: inline
}

.breadcrumb {
    border-bottom: 1px solid var(--brand-color-darker);
    white-space: nowrap;
    margin: 0-1em;
    padding: .5em 0 0 .5em;
    overflow: auto
}

.breadcrumb li {
    margin: -.5em 0 0;
    display: inline-block
}

.breadcrumb li:after {
    color: var(--border-color-darker);
    content: "›";
    vertical-align: middle;
    padding: 0
}

.breadcrumb li:last-child:after {
    width: 0;
    padding-right: 0
}

.breadcrumb a {
    vertical-align: middle;
    padding: .75em .5em;
    display: inline-block
}

.livery {
    vertical-align: text-top;
    width: 2.25em;
    height: 1.5em;
    margin-right: .5em;
    display: inline-block
}

.next {
    float: right
}

@media (min-height:480px) {}

#content {
    margin-bottom: 1.5em
}

footer li,
footer li a {
    display: inline
}

.horizontal li:before,
footer li:before {
    color: var(--border-color-darker);
    content: "  • ";
    font-weight: 700
}

.horizontal li:first-child:before,
footer li:first-child:before {
    display: none
}

footer {
    clear: both;
    text-align: center;
    margin-top: 1.5em
}

footer ul {
    border-top: 1px solid var(--brand-color-darker);
    clear: both;
    white-space: nowrap;
    margin: 0;
    padding: 1em;
    font-size: .75em;
    overflow: hidden
}

footer ul a {
    padding: 1.2em .25em
}

.no-ads footer {
    margin-bottom: 0
}

@media (min-width:30em) {
    .site-header ul a {
        padding-left: 1em
    }

    .site-header .search {
        position: relative;
        top: .7em
    }

    .site-header .search label {
        float: left;
        width: 8em;
        padding: 0;
        position: relative
    }

    .site-header .search input[type=search] {
        border: 1px solid var(--brand-color-darker);
        border-top-left-radius: .5em;
        border-bottom-left-radius: .5em;
        width: 100%;
        top: 0;
        left: 0
    }

    .site-header .search input[type=search]:focus {
        border-width: 1px
    }

    .site-header .search input[type=submit] {
        background: var(--brand-color-darker);
        border: 1px solid var(--brand-color-darker);
        float: right;
        border-top-left-radius: 0;
        border-bottom-left-radius: 0;
        margin: 0;
        display: block;
        top: 0
    }

    .site-header ul+.search {
        padding-right: .5em
    }
}

@media (min-width:48em) {
    header .search label {
        width: 10em
    }

    .narrow header div {
        width: 47.5em
    }

    .narrow main {
        width: 45.5em
    }

    h1 {
        font-size: 2em
    }
}


@media (min-width:56em) {
    header .search label {
        width: 10em
    }

    .wide header div {
        width: 55.5em
    }

    .wide main {
        width: 55.5em
    }

    h1 {
        font-size: 2em
    }
}

@media (min-width:62.5em) {
    .site-header div {
        padding: 0 1em
    }

    main {
        padding: 0 2em
    }

    .breadcrumb {
        margin: 0-2em;
        padding-left: 1.5em
    }
}

@media (min-width:970px) {}

@media (min-width:1200px) {}