698 lines
13 KiB
CSS
698 lines
13 KiB
CSS
/*
|
||
TailwindCSS JIT-Mode Input file.
|
||
Use TailwindCSS functions and directives here – https://tailwindcss.com/docs/functions-and-directives
|
||
About JIT-Mode: https://tailwindcss.com/docs/just-in-time-mode#styles-rebuild-in-an-infinite-loop
|
||
|
||
TailwindCSS CLI generates the css/index-tailwind-output.css file based on this file.
|
||
It is not used directly in the app.
|
||
*/
|
||
|
||
@tailwind base;
|
||
@tailwind components;
|
||
@tailwind utilities;
|
||
|
||
@layer utilities {
|
||
.z-above-map {
|
||
z-index: 10000;
|
||
}
|
||
|
||
.z-above-controls {
|
||
z-index: 10001;
|
||
}
|
||
|
||
.w-160 {
|
||
width: 40rem;
|
||
}
|
||
|
||
.bg-subtle {
|
||
background-color: var(--subtle-detail-color);
|
||
color: var(--subtle-detail-color-contrast);
|
||
}
|
||
|
||
.bg-unsubtle {
|
||
background-color: var(--unsubtle-detail-color);
|
||
color: var(--unsubtle-detail-color-contrast);
|
||
}
|
||
|
||
.bg-catch {
|
||
background-color: var(--catch-detail-color);
|
||
color: var(--catch-detail-color-contrast);
|
||
}
|
||
|
||
.rounded-left-full {
|
||
border-bottom-left-radius: 999rem;
|
||
border-top-left-radius: 999rem;
|
||
}
|
||
|
||
.rounded-right-full {
|
||
border-bottom-right-radius: 999rem;
|
||
border-top-right-radius: 999rem;
|
||
}
|
||
}
|
||
|
||
:root {
|
||
/* The main colour scheme of mapcomplete is configured here.
|
||
* For a custom styling, set 'customCss' in your layoutConfig and overwrite some of these.
|
||
*/
|
||
|
||
/* Main color of the application: the background and text colours */
|
||
--background-color: white;
|
||
/* Main text colour. Also styles some elements, such as the 'close popup'-button or 'back-arrow' (in mobile) */
|
||
--foreground-color: black;
|
||
|
||
/* A colour to indicate an error or warning */
|
||
--alert-color: #fee4d1;
|
||
|
||
/**
|
||
* Base colour of interactive elements, mainly the 'subtle button'
|
||
*
|
||
*/
|
||
--subtle-detail-color: #dbeafe;
|
||
--subtle-detail-color-contrast: black;
|
||
--subtle-detail-color-light-contrast: lightgrey;
|
||
|
||
/**
|
||
* A stronger variant of the 'subtle-detail-colour'
|
||
* Used as subtle button hover
|
||
*/
|
||
--unsubtle-detail-color: #bfdbfe;
|
||
--unsubtle-detail-color-contrast: black;
|
||
|
||
--catch-detail-color: #3a3aeb;
|
||
--catch-detail-color-contrast: white;
|
||
|
||
--non-active-tab-svg: var(--foreground-color);
|
||
--shadow-color: #00000066;
|
||
|
||
--return-to-the-map-height: 2em;
|
||
--image-carousel-height: 350px;
|
||
|
||
/* The border colour of the leaflet popup */
|
||
--popup-border: white;
|
||
|
||
/* Technical variable to make some dynamic behaviour possible; set by javascript. */
|
||
--variable-title-height: 0px;
|
||
}
|
||
|
||
html,
|
||
body {
|
||
height: 100%;
|
||
min-height: 100vh;
|
||
min-height: -webkit-fill-available;
|
||
margin: 0;
|
||
padding: 0;
|
||
background-color: var(--background-color);
|
||
color: var(--foreground-color);
|
||
font-family: "Helvetica Neue", Arial, sans-serif;
|
||
}
|
||
|
||
.leaflet-overlay-pane .leaflet-zoom-animated {
|
||
/* Another workaround to keep leaflet working */
|
||
width: initial !important;
|
||
height: initial !important;
|
||
box-sizing: initial !important;
|
||
}
|
||
|
||
.leaflet-marker-icon img {
|
||
-webkit-touch-callout: none; /* prevent callout to copy image, etc when tap to hold */
|
||
}
|
||
|
||
.leaflet-control-attribution {
|
||
display: flex;
|
||
}
|
||
|
||
.badge {
|
||
}
|
||
|
||
.badge svg {
|
||
/*Workaround for leaflet*/
|
||
width: unset !important;
|
||
height: 100% !important;
|
||
}
|
||
|
||
svg,
|
||
img {
|
||
box-sizing: content-box;
|
||
width: 100%;
|
||
height: 100%;
|
||
}
|
||
|
||
.titleicon img {
|
||
width: unset;
|
||
}
|
||
|
||
.titleicon svg {
|
||
width: unset;
|
||
}
|
||
.svg-catch svg path {
|
||
fill: var(--catch-detail-color) !important;
|
||
stroke: var(--catch-detail-color) !important;
|
||
}
|
||
|
||
.svg-unsubtle svg path {
|
||
fill: var(--unsubtle-detail-color) !important;
|
||
stroke: var(--unsubtle-detail-color) !important;
|
||
}
|
||
|
||
.svg-subtle svg path {
|
||
fill: var(--subtle-detail-color) !important;
|
||
stroke: var(--subtle-detail-color) !important;
|
||
}
|
||
|
||
.svg-foreground svg path {
|
||
fill: var(--foreground-color) !important;
|
||
stroke: var(--foreground-color) !important;
|
||
}
|
||
|
||
.no-images img {
|
||
display: none;
|
||
}
|
||
|
||
.weblate-link {
|
||
/* Weblate-links are the little translation icon next to translatable sentences. Due to their special nature, they are exempt from some rules */
|
||
}
|
||
|
||
.mapcontrol svg path {
|
||
fill: var(--subtle-detail-color-contrast) !important;
|
||
}
|
||
|
||
.red-svg svg path {
|
||
stroke: #d71010 !important;
|
||
}
|
||
|
||
a {
|
||
color: var(--foreground-color);
|
||
}
|
||
|
||
.text-white a {
|
||
color: var(--background-color);
|
||
}
|
||
|
||
.btn {
|
||
line-height: 1.25rem;
|
||
--tw-text-opacity: 1;
|
||
color: var(--catch-detail-color-contrast);
|
||
--tw-bg-opacity: 1;
|
||
background-color: var(--catch-detail-color);
|
||
display: inline-flex;
|
||
border-radius: 1.5rem;
|
||
padding-top: 0.75rem;
|
||
padding-bottom: 0.75rem;
|
||
padding-left: 1.25rem;
|
||
padding-right: 1.25rem;
|
||
font-size: large;
|
||
font-weight: bold;
|
||
transition: 100ms;
|
||
/*-- invisible border: rendered on hover*/
|
||
border: 3px solid var(--unsubtle-detail-color);
|
||
}
|
||
|
||
.btn:hover {
|
||
border: 3px solid var(--catch-detail-color);
|
||
}
|
||
|
||
.btn-secondary {
|
||
background-color: var(--catch-detail-color);
|
||
filter: saturate(0.5);
|
||
}
|
||
|
||
.btn-secondary:hover {
|
||
background-color: var(--catch-detail-color);
|
||
filter: unset;
|
||
}
|
||
|
||
.btn-disabled {
|
||
filter: saturate(0.3);
|
||
cursor: default;
|
||
}
|
||
|
||
.btn-disabled:hover {
|
||
border: 3px solid var(--unsubtle-detail-color);
|
||
}
|
||
|
||
.h-min {
|
||
height: min-content;
|
||
}
|
||
|
||
/* slider */
|
||
input[type="range"].vertical {
|
||
writing-mode: bt-lr; /* IE */
|
||
-webkit-appearance: slider-vertical; /* Chromium */
|
||
cursor: pointer;
|
||
}
|
||
|
||
@-moz-document url-prefix() {
|
||
input[type="range"].elevator::-moz-range-thumb {
|
||
background-color: #00000000 !important;
|
||
background-image: url("/assets/svg/elevator_wheelchair.svg");
|
||
width: 150px !important;
|
||
height: 30px !important;
|
||
border: 2px;
|
||
border-style: solid;
|
||
background-size: contain;
|
||
background-position: center center;
|
||
background-repeat: no-repeat;
|
||
cursor: pointer;
|
||
border-image: linear-gradient(to right, black 50%, transparent 50%) 100% 1;
|
||
padding-bottom: 5px;
|
||
}
|
||
}
|
||
|
||
.border-detail {
|
||
border-color: var(--foreground-color);
|
||
}
|
||
|
||
.w-min {
|
||
width: min-content;
|
||
}
|
||
|
||
.rounded-left-full {
|
||
border-bottom-left-radius: 999rem;
|
||
border-top-left-radius: 999rem;
|
||
}
|
||
|
||
.rounded-right-full {
|
||
border-bottom-right-radius: 999rem;
|
||
border-top-right-radius: 999rem;
|
||
}
|
||
|
||
.w-16-imp {
|
||
width: 4rem !important;
|
||
}
|
||
|
||
.w-32-imp {
|
||
width: 8rem !important;
|
||
}
|
||
|
||
.w-48-imp {
|
||
width: 12rem !important;
|
||
}
|
||
|
||
.link-underline a {
|
||
text-decoration: underline 1px var(--foreground-color);
|
||
}
|
||
|
||
a.link-underline {
|
||
text-decoration: underline 1px var(--foreground-color);
|
||
}
|
||
|
||
.link-no-underline a {
|
||
text-decoration: none;
|
||
}
|
||
|
||
li {
|
||
margin-left: 0.5em;
|
||
padding-left: 0.2em;
|
||
margin-top: 0.1em;
|
||
}
|
||
|
||
h2 {
|
||
font-size: large;
|
||
margin-top: 0.5em;
|
||
margin-bottom: 0.3em;
|
||
font-weight: bold;
|
||
}
|
||
|
||
h3 {
|
||
font-size: larger;
|
||
margin-top: 0.6em;
|
||
margin-bottom: 0;
|
||
font-weight: bold;
|
||
}
|
||
|
||
h3 {
|
||
font-size: larger;
|
||
margin-top: 0.6em;
|
||
margin-bottom: 0;
|
||
font-weight: bolder;
|
||
}
|
||
|
||
p {
|
||
padding-top: 0.1em;
|
||
}
|
||
|
||
li::marker {
|
||
content: "•";
|
||
}
|
||
|
||
.subtle-background {
|
||
background: var(--subtle-detail-color);
|
||
color: var(--subtle-detail-color-contrast);
|
||
}
|
||
|
||
.normal-background {
|
||
background: var(--background-color);
|
||
color: var(--foreground-color);
|
||
}
|
||
|
||
.subtle-lighter {
|
||
color: var(--subtle-detail-color-light-contrast);
|
||
}
|
||
|
||
.border-attention-catch {
|
||
border: 5px solid var(--catch-detail-color);
|
||
}
|
||
|
||
.border-invisible {
|
||
border: 5px solid #00000000;
|
||
}
|
||
|
||
.border-attention {
|
||
border-color: var(--catch-detail-color);
|
||
}
|
||
|
||
.direction-svg svg path {
|
||
fill: var(--catch-detail-color) !important;
|
||
}
|
||
|
||
#leafletDiv {
|
||
height: 100%;
|
||
}
|
||
|
||
.leaflet-popup-content-wrapper {
|
||
background-color: var(--background-color);
|
||
color: var(--foreground-color);
|
||
border: 2px solid var(--popup-border);
|
||
box-shadow: 0 3px 14px var(--shadow-color) !important;
|
||
}
|
||
|
||
.leaflet-container {
|
||
font: unset !important;
|
||
background-color: var(--background-color) !important;
|
||
}
|
||
|
||
.leaflet-popup-tip {
|
||
background-color: var(--popup-border) !important;
|
||
color: var(--popup-border) !important;
|
||
box-shadow: 0 3px 14px var(--shadow-color) !important;
|
||
}
|
||
|
||
.single-layer-selection-toggle {
|
||
position: relative;
|
||
width: 2em;
|
||
height: 2em;
|
||
flex-shrink: 0;
|
||
}
|
||
|
||
.single-layer-selection-toggle img {
|
||
max-height: 2em !important;
|
||
max-width: 2em !important;
|
||
}
|
||
|
||
.single-layer-selection-toggle svg {
|
||
max-height: 2em !important;
|
||
max-width: 2em !important;
|
||
}
|
||
|
||
.block-ruby {
|
||
display: block ruby;
|
||
}
|
||
|
||
.disable-links a {
|
||
pointer-events: none;
|
||
text-decoration: none !important;
|
||
color: var(--subtle-detail-color-contrast) !important;
|
||
}
|
||
|
||
.enable-links a {
|
||
pointer-events: unset;
|
||
text-decoration: underline !important;
|
||
color: unset !important;
|
||
}
|
||
|
||
.disable-links a.must-link,
|
||
.disable-links .must-link a {
|
||
/* Hide links if they are disabled */
|
||
display: none;
|
||
}
|
||
|
||
/**************** GENERIC ****************/
|
||
|
||
.alert {
|
||
background-color: var(--alert-color);
|
||
color: var(--foreground-color);
|
||
font-weight: bold;
|
||
border-radius: 1em;
|
||
margin: 0.25em;
|
||
text-align: center;
|
||
padding: 0.15em 0.3em;
|
||
}
|
||
|
||
.invalid {
|
||
box-shadow: 0 0 10px #ff5353;
|
||
height: min-content;
|
||
}
|
||
|
||
.shadow {
|
||
box-shadow: 0 0 10px var(--shadow-color);
|
||
}
|
||
|
||
.title-font span {
|
||
font-size: xx-large !important;
|
||
font-weight: bold;
|
||
}
|
||
|
||
.soft {
|
||
background-color: var(--subtle-detail-color);
|
||
color: var(--subtle-detail-color-contrast);
|
||
font-weight: bold;
|
||
border-radius: 1em;
|
||
margin: 0.25em;
|
||
text-align: center;
|
||
padding: 0.15em 0.3em;
|
||
}
|
||
|
||
.subtle {
|
||
color: #999;
|
||
}
|
||
|
||
.link-underline .subtle a {
|
||
text-decoration: underline 1px #7193bb88;
|
||
color: #7193bb;
|
||
}
|
||
|
||
.thanks {
|
||
background-color: #43d904;
|
||
font-weight: bold;
|
||
border-radius: 1em;
|
||
margin: 0.25em;
|
||
text-align: center;
|
||
padding: 0.15em 0.3em;
|
||
}
|
||
|
||
.clickable {
|
||
pointer-events: all;
|
||
}
|
||
|
||
.unclickable {
|
||
pointer-events: none !important;
|
||
}
|
||
|
||
@keyframes slide {
|
||
/* This is the animation on the marker to add a new point - it slides through all the possible presets */
|
||
from {
|
||
transform: translateX(0%);
|
||
}
|
||
|
||
to {
|
||
transform: translateX(calc(-100% + 42px));
|
||
}
|
||
}
|
||
|
||
.hand-drag-animation {
|
||
animation: hand-drag-animation 6s ease-in-out infinite;
|
||
transform-origin: 50% 125%;
|
||
}
|
||
|
||
@keyframes hand-drag-animation {
|
||
/* This is the animation on the little extra hand on the location input. If fades in, invites the user to interact/drag the map */
|
||
0% {
|
||
opacity: 0;
|
||
transform: rotate(-30deg);
|
||
}
|
||
|
||
6% {
|
||
opacity: 1;
|
||
transform: rotate(-30deg);
|
||
}
|
||
|
||
12% {
|
||
opacity: 1;
|
||
transform: rotate(-45deg);
|
||
}
|
||
|
||
24% {
|
||
opacity: 1;
|
||
transform: rotate(-00deg);
|
||
}
|
||
|
||
30% {
|
||
opacity: 1;
|
||
transform: rotate(-30deg);
|
||
}
|
||
|
||
36% {
|
||
opacity: 0;
|
||
transform: rotate(-30deg);
|
||
}
|
||
|
||
100% {
|
||
opacity: 0;
|
||
transform: rotate(-30deg);
|
||
}
|
||
}
|
||
|
||
/**************************************/
|
||
|
||
#topleft-tools {
|
||
display: block;
|
||
position: absolute;
|
||
z-index: 5000;
|
||
transition: all 500ms linear;
|
||
left: 0;
|
||
right: 0;
|
||
}
|
||
|
||
.welcomeMessage {
|
||
display: block;
|
||
max-width: calc(100vw - 5em);
|
||
width: 40em;
|
||
max-height: calc(100vh - 15em);
|
||
background-color: var(--background-color);
|
||
color: var(--foreground-color);
|
||
}
|
||
|
||
/***************** Info box (box containing features and questions ******************/
|
||
|
||
input {
|
||
color: var(--foreground-color);
|
||
}
|
||
|
||
.leaflet-popup-content {
|
||
width: 45em !important;
|
||
margin: 0.25rem !important;
|
||
}
|
||
|
||
.leaflet-div-icon {
|
||
background-color: unset !important;
|
||
border: unset !important;
|
||
}
|
||
|
||
.floating-element-width {
|
||
max-width: calc(100vw - 5em);
|
||
width: 40em;
|
||
}
|
||
|
||
.leaflet-div-icon svg {
|
||
width: calc(100%);
|
||
height: calc(100%);
|
||
}
|
||
|
||
/****** ShareScreen *****/
|
||
|
||
.literal-code {
|
||
display: inline-block;
|
||
background-color: lightgray;
|
||
padding: 0.5em;
|
||
word-break: break-word;
|
||
color: black;
|
||
box-sizing: border-box;
|
||
}
|
||
|
||
.code {
|
||
display: inline-block;
|
||
background-color: lightgray;
|
||
padding: 0.5em;
|
||
word-break: break-word;
|
||
color: black;
|
||
box-sizing: border-box;
|
||
}
|
||
|
||
/** Switch layout **/
|
||
.small-image img {
|
||
height: 1em;
|
||
max-width: 1em;
|
||
}
|
||
|
||
.small-image {
|
||
height: 1em;
|
||
max-width: 1em;
|
||
}
|
||
|
||
.slideshow-item img {
|
||
height: var(--image-carousel-height);
|
||
width: unset;
|
||
}
|
||
|
||
.animate-height {
|
||
transition: max-height 0.5s ease-in-out;
|
||
overflow-y: hidden;
|
||
}
|
||
|
||
.zebra-table tr:nth-child(even) {
|
||
background-color: #f2f2f2;
|
||
}
|
||
|
||
.layer-toggle {
|
||
/* The checkbox that toggles a single layer */
|
||
}
|
||
|
||
.glowing-shadow {
|
||
-webkit-animation: glowing 1s ease-in-out infinite alternate;
|
||
-moz-animation: glowing 1s ease-in-out infinite alternate;
|
||
animation: glowing 1s ease-in-out infinite alternate;
|
||
}
|
||
@-webkit-keyframes glowing {
|
||
from {
|
||
box-shadow: 0 0 20px 10px #eaaf2588, inset 0 0 0px 1px #eaaf25;
|
||
}
|
||
to {
|
||
box-shadow: 0 0 20px 20px #eaaf2588, inset 0 0 5px 1px #eaaf25;
|
||
}
|
||
}
|
||
|
||
.mapping-icon-small-height {
|
||
/* A mapping icon type */
|
||
height: 1.5rem;
|
||
margin-right: 0.5rem;
|
||
width: unset;
|
||
}
|
||
|
||
.mapping-icon-medium-height {
|
||
/* A mapping icon type */
|
||
height: 3rem;
|
||
margin-right: 0.5rem;
|
||
width: unset;
|
||
}
|
||
|
||
.mapping-icon-large-height {
|
||
/* A mapping icon type */
|
||
height: 5rem;
|
||
margin-right: 0.5rem;
|
||
width: unset;
|
||
}
|
||
|
||
.mapping-icon-small {
|
||
/* A mapping icon type */
|
||
width: 1.5rem;
|
||
max-height: 1.5rem;
|
||
margin-right: 0.5rem;
|
||
}
|
||
|
||
.mapping-icon-medium {
|
||
/* A mapping icon type */
|
||
width: 3rem;
|
||
max-height: 3rem;
|
||
margin-right: 1rem;
|
||
margin-left: 1rem;
|
||
}
|
||
|
||
.mapping-icon-large {
|
||
/* A mapping icon type */
|
||
width: 6rem;
|
||
max-height: 5rem;
|
||
margin-top: 0.5rem;
|
||
margin-bottom: 0.5rem;
|
||
margin-right: 1.5rem;
|
||
margin-left: 1.5rem;
|
||
}
|