body {
  font-size: 1rem;
}
body .small {
  font-size: 0.8rem;
}
:is(h1, .h1).large {
  font-size: var(--step-6);
}
:is(h2, .h2).large, :is(h1, .h1) {
  font-size: var(--step-5);
}
:is(h3, .h3).large, :is(h2, .h2), :is(h1, .h1).small {
  font-size: var(--step-4);
}
:is(h4, .h4).large, :is(h3, .h3), :is(h2, .h2).small {
  font-size: var(--step-3);
}
:is(h5, .h5).large, :is(h4, .h4), :is(h3, .h3).small {
  font-size: var(--step-2);
}
:is(h6, .h6).large, :is(h5, .h5), :is(h4, .h4).small {
  font-size: var(--step-1);
}
:is(h6, .h6), :is(h5, .h5).small {
  font-size: var(--step-0);
}
:is(h6, .h6).small {
  font-size: var(--step--1);
}
.flashes .flash {
  display: flex;
  flex-flow: row nowrap;
  align-items: center;
  justify-content: space-between;
}
.flashes .flash.flash-success {
  background-color: var(--success-container);
  color: var(--on-success-container);
}
.flashes .flash.flash-danger {
  background-color: var(--error-container);
  color: var(--on-error-container);
}
.top-header {
  background-image: linear-gradient(to right, var(--primary), var(--secondary));
}
.top-header + header:empty {
  min-block-size: 0;
}
.top-header ~ footer {
  background-color: var(--surface-container);
}
.top-breadcrumbs .breadcrumb {
  margin: 0;
}
.top-breadcrumbs .breadcrumb-item.active {
  font-weight: bold;
}
form.narrow-form {
  max-width: 36em;
  margin-inline: auto;
}
.form-field label {
  font-size: 1em;
  font-weight: 500;
}
.form-field .field {
  margin-top: 0;
  margin-bottom: 0;
}
.repeatable-field {
  display: grid;
  gap: 0.5rem;
  grid-template-columns: 1fr auto;
}
.repeatable-field > .field {
  grid-column: 1;
}
.repeatable-field > .remove-button {
  grid-column: 2;
}
.repeatable-field > .add-button {
  grid-column: 1/-1;
}
@media (width > 600px) {
  .repeatable-field {
    grid-template-columns: 1fr auto auto;
  }
  .repeatable-field > .field {
    grid-column: 1;
  }
  .repeatable-field > .remove-button {
    grid-column: 2;
  }
  .repeatable-field > .add-button {
    grid-column: 3;
  }
}
.map-with-coords {
  height: min(50vh, 25rem);
}
.map-with-coords > .mapboxgl-map {
  height: 100%;
}
fieldset.geocode-fieldset .row {
  margin: 0 0 0.5rem;
}
.geocode-results {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(22rem, 1fr));
  gap: 1rem;
}
.lat-lon-fields {
  display: grid;
  -moz-column-gap: 0.5em;
       column-gap: 0.5em;
}
.lat-lon-fields .fields-hint {
  font-size: 200%;
  align-self: start;
  justify-self: start;
}
.lat-lon-fields:where(.lat-lon-fields-with-hint) {
  grid-template-columns: auto 1fr;
}
.lat-lon-fields:where(.lat-lon-fields-with-hint) .fields-hint {
  grid-area: 1/1/span 2;
}
.lat-lon-fields:where(.lat-lon-fields-with-hint) .field {
  grid-column: 2;
}
@media (width >= 600px) {
  .lat-lon-fields {
    -moz-column-gap: 1rem;
         column-gap: 1rem;
    grid-template-columns: min(40%, 15rem) min(40%, 15rem) auto;
  }
  .lat-lon-fields .fields-hint, .lat-lon-fields .field {
    grid-area: unset;
  }
}
ul.trips {
  list-style: none;
  padding: 0;
  -moz-column-width: 20ch;
       column-width: 20ch;
}
ul.trips li {
  -moz-column-break-inside: avoid;
       break-inside: avoid;
}
ul.trips a {
  display: block;
  box-shadow: none;
  transition: box-shadow 0.2s, border-color 0.2s;
  border: 3px solid transparent;
  text-decoration: none;
}
ul.trips a:hover, ul.trips a:focus {
  box-shadow: 0.25em 0.25em 0.5em var(--highlight);
  border-color: var(--highlight);
}
.trip-map {
  height: 100%;
}
.trip-map .trip-title {
  display: flex;
  align-items: baseline;
}
.trip-map .buttons-row {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 5;
  backdrop-filter: blur(7px);
  border-top: 2px solid var(--surface-container-highest);
  transition: 0.25s transform;
}
.trip-map .buttons-row:not(.active) {
  transform: translateY(100%);
}
.trip-map .buttons-row .button-close {
  float: right;
  margin-right: 0.25rem;
  margin-top: 0.25rem;
}
.trip-map .buttons-row h4 {
  font-size: 1rem;
  text-align: center;
  margin: 0.25rem 0;
}
.trip-map .buttons-row ul {
  list-style: none;
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  margin: 0;
  padding: 0.5em;
  gap: 0.5em;
}
.trip-map .buttons-row ul li {
  margin: 0;
  padding: 0;
}
.trip-map .buttons-row ul a {
  border: 2px solid var(--surface-container-highest);
  backdrop-filter: blur(15px);
  border-radius: 2em;
  color: var(--on-surface);
}
.trip-map .buttons-row ul a:hover, .trip-map .buttons-row ul a:focus {
  background-color: hsla(0, 0%, 79%, 0.2);
}
body:has(> main.show-trip) {
  --main-row-size: calc(100vh - 9.5rem);
}
main.show-trip .trip-title {
  display: flex;
  flex-flow: row nowrap;
  align-items: baseline;
}
main.show-trip .trip-title > h1 .trip-title-author {
  font-size: 65%;
  font-style: italic;
  color: var(--surface-dim);
  margin-left: 0.5em;
}
main.show-trip .trip-title > h1 .trip-title-author .you {
  -webkit-text-decoration: underline dotted 2px;
          text-decoration: underline dotted 2px;
}
main.show-trip .app-drawer-button {
  position: absolute;
  top: 8rem;
  left: 1rem;
  z-index: 99;
}
.trip-point-items ul {
  list-style: none;
  padding-inline-start: 0;
}
.trip-point-items {
  --decoration-color: var(--type-color, #aaa);
  border-left: 4px solid var(--decoration-color);
}
.trip-point-items h2 {
  border-bottom: 6px solid;
  -o-border-image: linear-gradient(to right, var(--decoration-color), var(--decoration-color) 30%, transparent 100%) 1;
     border-image: linear-gradient(to right, var(--decoration-color), var(--decoration-color) 30%, transparent 100%) 1;
}
.trip-point-item {
  display: flex;
  flex-flow: row nowrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5em;
}
.trip-point-item address {
  margin-block-start: initial;
}
.trip-point-item .item-links {
  white-space: nowrap;
}
.wday-default {
  background-color: black;
  color: white;
}
.wday-fri {
  background-color: var(--tertiary);
  color: var(--on-tertiary);
}
.wday-sat {
  background-color: var(--primary);
  color: var(--on-primary);
}
.wday-sun {
  background-color: yellow;
  color: black;
}
.schedule-table {
  width: min(24rem, 100%);
  contain: layout;
}
.schedule-table td, .schedule-table th {
  max-inline-size: initial;
}
.schedule-table .weekday {
  inline-size: 8ch;
}
.field-schedule {
  padding-right: 1em;
}
.field-schedule td.control {
  inline-size: -moz-max-content;
  inline-size: max-content;
  min-inline-size: 2.2em;
}
.schedule-buttons {
  position: absolute;
  right: 0;
  display: flex;
  flex-flow: column;
  z-index: 1;
}
.schedule-buttons button {
  margin: 0;
}
.schedule-buttons button + button {
  margin-top: 0.25em;
}
.show-point section {
  margin: 1rem 0;
  align-items: stretch;
}
.show-point section > * {
  max-width: 100%;
}
.show-point section > figure {
  flex: 1 0 auto;
  text-align: center;
  margin: 0;
  float: right;
}
.show-point section > figure img {
  max-width: 100%;
}
.show-point section > article {
  flex: 10 1 min-content;
}
.show-point .websites {
  gap: 0;
}
.show-point .websites li {
  max-width: 100%;
  overflow: clip;
  text-overflow: ellipsis;
}
.show-point .websites li a {
  white-space: nowrap;
  display: initial;
  padding: 0.5em;
}
/* Overrides */
.mapboxgl-control-container {
  position: initial;
}
:is(.mapboxgl-ctrl-group, .mapboxgl-ctrl-attrib) :is(.mapboxgl-ctrl button) {
  margin: 0;
  min-width: initial;
  padding: 0;
  border-radius: revert;
}
:is(.mapboxgl-ctrl-group, .mapboxgl-ctrl-attrib) :is(.mapboxgl-ctrl button):hover, :is(.mapboxgl-ctrl-group, .mapboxgl-ctrl-attrib) :is(.mapboxgl-ctrl button):focus {
  box-shadow: none;
}
:where(a, :-moz-any-link, .link):not(.button, .chip, menu a) {
  color: var(--primary-dark) !important;
  text-decoration: underline;
}
:where(a, :any-link, .link):not(.button, .chip, menu a) {
  color: var(--primary-dark) !important;
  text-decoration: underline;
}
.primary-border {
  border-color: var(--primary-dark) !important;
}
.primary-text {
  color: var(--primary-dark) !important;
}
:is(.checkbox, .radio) > input + span::before {
  color: var(--primary-dark) !important;
}
.secondary-border {
  border-color: var(--secondary-dark) !important;
}
.secondary-text {
  color: var(--secondary-dark) !important;
}
.success {
  background-color: var(--success);
  color: var(--on-success);
}
.field textarea {
  white-space-collapse: revert;
}
:has(> main) {
  grid-template-rows: auto auto var(--main-row-size, 1fr) auto auto;
}
/* Utils */
.invisible {
  display: none;
}
:is(ul, ol).list-no-style {
  list-style: none;
}
.htmx-indicator {
  /* Initial style to load while HTMX is loading */
  opacity: 0;
  visibility: hidden;
}
.htmx-indicator.htmx-request {
  visibility: visible;
}