/* @link https://utopia.fyi/type/calculator?c=320,16,1.125,1240,20,1.125,7,2,&s=0.75|0.5|0.25,1.5|2|3|4|6,s-l&g=s,l,xl,12 */
:root {
  --step--2: clamp(0.7901rem, 0.7214rem + 0.3435vw, 0.9877rem);
  --step--1: clamp(0.8889rem, 0.8116rem + 0.3865vw, 1.1111rem);
  --step-0: clamp(1rem, 0.913rem + 0.4348vw, 1.25rem);
  --step-1: clamp(1.125rem, 1.0272rem + 0.4891vw, 1.4063rem);
  --step-2: clamp(1.2656rem, 1.1556rem + 0.5503vw, 1.582rem);
  --step-3: clamp(1.4238rem, 1.3rem + 0.6191vw, 1.7798rem);
  --step-4: clamp(1.6018rem, 1.4625rem + 0.6964vw, 2.0023rem);
  --step-5: clamp(1.802rem, 1.6453rem + 0.7835vw, 2.2525rem);
  --step-6: clamp(2.0273rem, 1.851rem + 0.8814vw, 2.5341rem);
  --step-7: clamp(2.2807rem, 2.0824rem + 0.9916vw, 2.8509rem);
}
/* Color scheme */
:root, body.light, body.dark {
  --surface: hsl(0, 0%, 99%);
  --surface-container-low: hsl(0, 0%, 96%);
  --surface-container: hsl(0, 0%, 90%);
  --surface-container-high: hsl(0, 0%, 85%);
  --surface-container-highest: hsl(0, 0%, 79%);
  --on-surface: hsl(300, 4%, 13%);
  --inverse-surface: var(--on-surface);
  --inverse-on-surface: var(--surface);
  --primary: oklch(83% 0.088 340);
  --primary-dark: oklch(50% 0.1 340);
  --on-primary: var(--on-surface);
  --primary-container: oklch(90% 0.07 340);
  --on-primary-container: var(--on-surface);
  --secondary: oklch(90% 0.06 53.87);
  --secondary-dark: oklch(40% 0.095 53.87);
  --on-secondary: var(--secondary-dark);
  --secondary-container: var(--secondary);
  --on-secondary-container: var(--on-surface);
  --success: oklch(57% 0.15 129);
  --on-success: var(--inverse-on-surface);
  --success-container: oklch(90% 0.126 129);
  --on-success-container: var(--on-surface);
  --tertiary: oklch(40% 0.095 53.87);
  --on-tertiary: var(--inverse-on-surface);
  --tertiary-container: oklch(90% 0.06 53.87);
  --on-tertiary-container: oklch(40% 0.095 53.87);
  --highlight: oklch(63% 0.225 1.1);
  --base-marker-color: oklch(90% 0.07 340);
}
@supports (background-color: color-mix(in lch, black, white)) {
  :root {
    --surface-variant: color-mix(in lch, var(--secondary), var(--surface));
    --on-surface-variant: var(--secondary-dark);
  }
}
body {
  font-size: 1rem;
}
body .small {
  font-size: 0.8rem;
}
h1, .h1 {
  font-size: var(--step-5);
}
h2, .h2, h1.small {
  font-size: var(--step-4);
}
h3, .h3, h2.small {
  font-size: var(--step-3);
}
h4, .h4, h3.small {
  font-size: var(--step-2);
}
h5, .h5, h4.small {
  font-size: var(--step-1);
}
h6, .h6, h5.small {
  font-size: var(--step-0);
}
.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-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;
}
ul.trips a:hover, ul.trips a:focus {
  box-shadow: 0.25em 0.25em 0.5em var(--highlight);
  border-color: var(--highlight);
}
.trip-map {
  min-height: 60vh;
}
.trip-map .trip-title {
  display: flex;
  align-items: baseline;
}
.trip-map .buttons-row {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 5;
  -webkit-backdrop-filter: blur(7px);
          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);
  -webkit-backdrop-filter: blur(15px);
          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);
}
main.show-trip {
  display: flex;
  flex-flow: column;
  gap: 0.5rem;
}
@media (width > 992px) {
  main.show-trip {
    flex-flow: row nowrap;
    flex: 0 0 calc(100vh - 9rem);
  }
  main.show-trip .app {
    flex-grow: 1;
    overflow-y: scroll;
  }
  main.show-trip .trip-map {
    order: 1;
    flex-basis: 60%;
  }
}
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;
}
.trip-point-items {
  --decoration-color: var(--type-color, #aaa);
  border-left: 4px solid var(--decoration-color);
}
.trip-point-items ul {
  list-style: none;
  padding-inline-start: 0;
}
.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;
}
.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;
}
:is(a, :-moz-any-link, .link):not(.button, .chip, menu a) {
  color: var(--primary-dark) !important;
  text-decoration: underline;
}
:is(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;
}
/* Utils */
.invisible {
  display: none;
}
:is(ul, ol).list-no-style {
  list-style: none;
}