MapComplete/src/index.css

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

745 lines
16 KiB
CSS
Raw Normal View History

/*
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;
:root {
/*
* The main colour scheme of mapcomplete is configured here.
* For a custom styling, set 'customCss' in your layoutConfig and overwrite some of these.
*/
2022-02-04 00:45:22 +01:00
2024-06-18 03:33:11 +02:00
/* No support for dark mode yet, we disable it to prevent some elements to suddenly toggle */
color-scheme: only light;
/* 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 scheme to indicate an error or warning */
--alert-color: #fee4d1;
--alert-foreground-color: var(--foreground-color);
--low-interaction-background: #eeeeee;
--low-interaction-background-50: #eeeeee90;
--low-interaction-foreground: black;
--low-interaction-border: #dcdcdc;
--interactive-background: #dddddd;
--interactive-foreground: black;
--interactive-contrast: #cd1dcd;
--interaction-border: #bfbfbf;
--button-background-primary: #191919;
--button-background-hover: #484848;
--button-primary-background-hover: rgba(48, 47, 47, 0.94);
--button-foreground: white;
--button-background: #fafafa;
--button-border: #B8B8B8;
--disabled: #B8B8B8;
--disabled-font: #B8B8B8;
--catch-detail-color: var(--background-color);
--catch-detail-foregroundcolor: var(--foreground-color);
--catch-detail-color-contrast: var(--interactive-contrast);
--image-carousel-height: 350px;
/** Technical value, used by icon.svelte
*/
--svg-color: #000000;
}
@font-face {
font-family: "Source Sans Pro";
/*This path might seem incorrect. However, 'index.css' will be compiled and placed in 'public/css', from where this path _is_ correct*/
2024-10-09 22:31:05 +02:00
src: url("../assets/fonts/source-sans-pro.regular.ttf") format("woff");
2024-06-16 19:00:43 +02:00
}
/***********************************************************************\
* Various tweaks and settings to make some behaviours more predictable *
\***********************************************************************/
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);
2024-06-16 19:00:43 +02:00
font-family: 'Source Sans Pro';
font-style: normal;
font-weight: 400;
font-size: 16px;
line-height: 150%;
}
svg,
img {
box-sizing: content-box;
width: 100%;
height: 100%;
}
li {
margin-left: 0.5em;
padding-left: 0.2em;
margin-top: 0.1em;
2022-02-01 19:02:46 +01:00
}
li::marker {
content: "•";
}
h1 {
font-size: xx-large;
margin-top: 0.6em;
margin-bottom: 0.4em;
font-weight: bold;
}
h2 {
font-size: x-large;
margin-top: 0.5em;
margin-bottom: 0; /*Disable margin bottom to play nicely with accordeons from flowbite*/
font-weight: bold;
}
h3 {
font-size: larger;
margin-top: 0.6em;
margin-bottom: 0;
font-weight: bold;
2022-02-01 19:02:46 +01:00
}
p {
padding-top: 0.1em;
}
2022-02-01 19:02:46 +01:00
input {
color: var(--foreground-color);
2022-04-01 12:51:55 +02:00
}
2024-04-24 02:44:31 +02:00
input[type="text"] {
width: 100%;
2023-05-16 03:27:49 +02:00
}
/************************* BIG CATEGORIES ********************************/
/**
* The main classes that dictate the structure of the entire app,
* and some interactive elements
*/
.normal-background {
background: var(--background-color);
color: var(--foreground-color);
}
.low-interaction {
background: var(--low-interaction-background);
color: var(--low-interaction-foreground);
}
2022-08-19 10:40:57 +02:00
.interactive {
background: var(--interactive-background);
color: var(--interactive-foreground);
}
.border-interactive {
border: 2px dashed var(--interactive-contrast);
border-radius: 0.5rem;
}
.border-low-interaction {
2025-04-22 01:19:52 +02:00
border-color: var(--interaction-border);
border-style: dashed;
}
.border-region {
border: 2px dashed var(--interactive-background);
border-radius: 0.5rem;
}
2024-09-02 03:47:54 +02:00
.box-shadow {
box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
}
/******************* Styling of input elements **********************/
/**
* This very important section defines what the various input elements look like within the 'low-interaction' and 'interactive'-blocks
*/
2024-06-16 19:00:43 +02:00
/********* BUTTONS ***********/
2024-06-16 19:00:43 +02:00
button, .button {
box-sizing: border-box;
2023-08-23 11:11:53 +02:00
2024-06-16 19:00:43 +02:00
/* Auto layout */
display: flex;
column-gap: 0.25rem;
justify-content: center;
align-items: center;
padding: 0.25rem 1rem;
margin: 0.25rem;
background: var(--button-background);
border: 2px solid var(--button-border);
border-radius: 7px;
transition: background-color 200ms;
}
.low-interaction button{
2024-06-16 19:00:43 +02:00
background: var(--background-color);
2022-04-23 15:20:54 +02:00
}
2024-06-18 03:33:11 +02:00
.group > button {
padding-right: 1rem !important; /*Flowbite workaround */
}
2024-06-16 19:00:43 +02:00
button.w-full {
margin-left: 0;
2022-04-23 15:20:54 +02:00
}
button.primary:hover:not(.disabled), .button.primary:hover:not(.disabled) {
background-color: var(--button-primary-background-hover);
border: 2px solid var(--interactive-contrast)
}
button:hover:not(.disabled):not(.as-link):not(.primary), .button:hover:not(.disabled):not(.as-link):not(.primary) {
2024-06-16 19:00:43 +02:00
background-color: var(--low-interaction-background);
2021-04-12 13:05:30 +02:00
}
2024-06-16 19:00:43 +02:00
button:focus, .button:focus {
border-color: var(--interactive-contrast);
}
2024-06-17 04:27:08 +02:00
.focus {
border: 2px solid var(--interactive-contrast);
}
2024-06-16 19:00:43 +02:00
button.primary, .button.primary {
color: var(--button-foreground);
background-color: var(--button-background-primary);
border: 2px solid var(--button-background-primary)
2021-04-12 13:05:30 +02:00
}
2024-06-16 19:00:43 +02:00
button.disabled {
border-color: var(--disabled-font);
color: var(--disabled-font);
2024-07-09 13:05:53 +02:00
cursor: unset;
}
2024-06-17 04:27:08 +02:00
button.disabled svg path {
transition: all 200ms;
}
2024-06-17 04:27:08 +02:00
button.disabled svg path {
fill: var(--disabled-font);
stroke: var(--disabled-font);
2024-06-17 04:27:08 +02:00
}
2024-06-16 19:00:43 +02:00
button.primary.disabled, .button.primary.disabled {
color: var(--button-foreground);
background-color: var(--disabled);
}
2024-06-16 19:00:43 +02:00
.low-interaction button:hover:not(.disabled):not(.as-link), .low-interaction .button:hover:not(.disabled):not(.as-link) {
box-sizing: border-box;
background-color: var(--interactive-background);
}
2024-06-16 19:00:43 +02:00
button.as-link {
background-color: unset;
display: inline-flex;
justify-content: start;
border: none;
border-radius: 0;
text-decoration: underline;
2024-07-25 15:03:58 +02:00
-webkite-text-decoration: underline;
2024-06-16 19:00:43 +02:00
box-shadow: none;
margin: 0;
padding: 0;
}
2024-08-26 13:09:46 +02:00
button.unstyled, .button-unstyled button {
2024-08-15 01:51:33 +02:00
background-color: unset;
display: inline-flex;
justify-content: start;
border: none;
2024-08-26 13:09:46 +02:00
box-shadow: none !important;
2024-08-15 01:51:33 +02:00
margin: 0;
padding: 0;
}
/****** Tablist elements *****/
.tablist {
margin: 0.25rem;
padding: 0.5rem;
border: 2px dashed var(--button-background-hover);
border-radius: 0.5rem;
display: flex;
justify-content: center;
2025-08-28 22:41:13 +02:00
flex-wrap: wrap;
}
.tab {
border: unset;
border-radius: 0;
transition: all;
color: var(--foreground-color);
border-bottom: 2px solid var(--foreground-color);
font-weight: bold;
margin: 0.25rem;
padding: 0.25rem;
padding-left: 0.75rem;
padding-right: 0.75rem;
}
.tab-selected {
opacity: 100%;
background: var(--interactive-background);
}
/* Actually used, don't remove*/
.tab-unselected {
background: #00000000 !important;
opacity: 60%;
}
.tab-unselected:hover {
background: var(--interactive-background);
}
2024-06-16 19:00:43 +02:00
/******* Other input elements ******/
2024-06-16 19:00:43 +02:00
.hover-alert:hover {
color: var(--interactive-contrast)
2023-05-14 03:24:13 +02:00
}
2024-06-16 19:00:43 +02:00
.links-w-full a:not(.weblate-link), .links-w-full button.as-link {
display: flex;
column-gap: 0.25rem;
padding-left: 0.5rem;
padding-right: 0.5rem;
width: 100%;
2023-05-14 03:24:13 +02:00
}
2023-05-11 17:29:25 +02:00
select {
border: 2px solid var(--low-interaction-border);
color: var(--foreground-color) !important;
background-color: var(--low-interaction-background) !important;
}
.low-interaction select {
border: 2px solid var(--interaction-border);
color: var(--foreground-color) !important;
background-color: var(--interactive-background) !important;
}
select:hover {
border-color: var(--interactive-contrast);
}
2024-04-24 02:44:31 +02:00
.neutral-label {
/** This label styles as normal text. It's power comes from the many :not(.neutral-label) entries.
* Placed here for autocompletion
*/
2023-12-29 22:46:02 +01:00
}
label:not(.neutral-label):not(.button) {
/**
* Label should _contain_ the input element
*/
padding: 0.25rem;
padding-right: 0.5rem;
padding-left: 0.5rem;
margin: 0.25rem;
border-radius: 0.5rem;
width: 100%;
box-sizing: border-box;
transition: all 250ms;
2023-12-29 22:46:02 +01:00
}
label.button {
width: 100%;
2023-12-29 22:46:02 +01:00
}
label:hover:not(.neutral-label) {
background-color: var(--low-interaction-background);
2023-12-29 22:46:02 +01:00
}
label.checked:not(.neutral-label) {
2024-06-17 04:27:08 +02:00
color: var(--foreground-color);
background-color: var(--low-interaction-background);
2023-12-29 22:46:02 +01:00
}
textarea {
color: black;
}
h2.group {
/* For flowbite accordions */
margin: 0;
top: 0;
position: sticky;
z-index: 12;
}
.group button {
/* For flowbite accordions */
border-radius: 0;
}
/************************* OTHER CATEGORIES ********************************/
/**
* Smaller categories which convey some semantic information but don't define bigger blocks.
* As they are _semantic_ categories, they can be styled
*/
.thanks {
/* The class to indicate 'operation successful' or 'thank you for contributing' */
font-weight: bold;
border-radius: 1em;
margin: 0.25em;
text-align: center;
padding: 0.25rem;
padding-left: 0.5rem;
padding-right: 0.5rem;
border: 3px dotted #58cd27;
background-color: #58cd2722;
2021-04-12 13:05:30 +02:00
}
.alert {
/* The class to convey important information, e.g. 'invalid', 'something went wrong', 'warning: testmode', ... */
background-color: var(--alert-color);
color: var(--alert-foreground-color);
font-weight: bold;
border-radius: 1em;
margin: 0.25em;
text-align: center;
padding: 0.15em 0.7em;
border: 2px dotted #ff9143;
2021-04-12 13:05:30 +02:00
}
.warning {
/* The class to convey important information, but not as grave as 'alert' */
2025-07-18 14:15:37 +02:00
background-color: var(--alert-color);
color: var(--alert-foreground-color);
font-weight: bold;
border-radius: 1em;
margin: 0.25em;
text-align: center;
padding: 0.15em 0.3em;
border: 3px dotted #ff9143;
}
.low-interaction .warning {
background-color: var(--interactive-background);
}
.low-interaction .interactive {
background-color: var(--interactive-background);
}
.subtle {
/* For all information that is not important for 99% of the users */
color: #666;
font-weight: normal;
2021-04-12 13:05:30 +02:00
}
.low-interaction .subtle {
color: #444;
}
.interactive .subtle {
color: #333;
}
.link-underline .subtle a {
text-decoration: underline 1px #7193bb88;
-webkit-text-decoration: underline;
color: #7193bb;
2021-04-12 13:05:30 +02:00
}
.literal-code,
code {
/* A codeblock */
display: inline-block;
background-color: lightgray;
padding: 0.1rem;
padding-left: 0.35rem;
padding-right: 0.35rem;
word-break: break-word;
color: black;
box-sizing: border-box;
font-family: monospace;
2021-04-12 13:05:30 +02:00
}
.interactive .literal-code {
background-color: #b3b3b3;
2021-03-13 19:07:38 +01:00
}
.frozen-glass {
backdrop-filter: blur(1px);
background: rgba(100, 100, 100, 0.50);
}
/************************** UTILITY ************************/
/**
* Utility classes are there for a specific function to pin down browser behaviour (and cannot be changed)
*/
.text-white a {
/* Used solely in 'imageAttribution' and in many themes*/
color: var(--background-color);
2021-10-02 17:57:54 +02:00
}
.h-full-child > div {
height: 100%;
}
2023-05-18 15:44:54 +02:00
.bg-black-transparent {
background-color: #00000088;
2023-05-18 15:44:54 +02:00
}
2024-08-29 12:16:35 +02:00
.bg-black-light-transparent {
background-color: #00000044;
}
.block-ruby {
display: block ruby;
}
.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;
}
.no-images img {
/* Used solely in 'imageAttribution' and in many themes for the label*/
display: none;
}
.weblate-link {
display: inline-block;
flex-shrink: 0;
margin: 0;
padding: 0.25rem;
width: 1.2rem;
height: 1.2rem;
border: unset;
border-radius: 5rem;
backdrop-filter: var(--low-interaction-background);
2023-05-18 15:44:54 +02:00
}
.no-weblate .weblate-link {
display: none !important;
}
.link-underline a {
text-decoration: underline 1px var(--foreground-color);
-webkit-text-decoration: underline;
2024-07-25 15:03:58 +02:00
}
a.link-underline {
text-decoration: underline 1px var(--foreground-color);
-webkit-text-decoration: underline;
}
.link-no-underline a, a.link-no-underline {
text-decoration: none;
}
.disable-links a {
pointer-events: none;
text-decoration: none !important;
color: var(--foreground-color) !important;
}
.enable-links a {
pointer-events: unset;
text-decoration: underline !important;
-webkit-text-decoration: underline !important;
color: unset !important;
}
a:hover {
background-color: var(--low-interaction-background);
}
.disable-links a.must-link,
.disable-links .must-link a {
/* Hide links if they are disabled */
display: none;
}
.zebra-table tr:nth-child(even) {
background-color: #f2f2f2;
}
.no-bold b {
font-weight: normal;
}
/************************* MISC ELEMENTS *************************/
.selected svg:not(.noselect *) path.selectable {
/* A marker on the map gets the 'selected' class when it's properties are displayed
*/
stroke: white !important;
stroke-width: 20px !important;
overflow: visible !important;
-webkit-animation: glowing-drop-shadow 1s ease-in-out infinite alternate;
-moz-animation: glowing-drop-shadow 1s ease-in-out infinite alternate;
animation: glowing-drop-shadow 1s ease-in-out infinite alternate;
}
.selected .light-icon svg:not(.noselect *) path.selectable {
stroke: #4a4a4a !important;
stroke-width: 10px !important;
}
.selected svg {
/* A marker on the map gets the 'selected' class when it's properties are displayed
*/
overflow: visible !important;
}
svg.apply-fill path {
fill: var(--svg-color);
}
2023-12-18 01:30:02 +01:00
.compass_arrow {
width: calc(2.5rem - 1px);
height: calc(2.5rem - 1px);
2023-12-18 01:30:02 +01:00
}
.in-markdown p, .in-markdown ol, .in-markdown ul {
padding-top: 0.5rem;
padding-bottom: 0.5rem;
}
2023-12-18 01:30:02 +01:00
@media (min-width: 640px) {
.compass_arrow {
width: calc(2.75rem - 1px);
height: calc(2.75rem - 1px);
}
2023-12-18 01:30:02 +01:00
}
@-webkit-keyframes glowing-drop-shadow {
from {
filter: drop-shadow(5px 5px 60px rgb(128 128 128 / 0.6));
}
to {
filter: drop-shadow(5px 5px 80px rgb(0.5 0.5 0.5 / 0.8));
}
}
@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));
}
}
2020-07-01 02:12:33 +02:00
2020-11-06 01:58:26 +01:00
2025-02-22 23:42:29 +01:00
.badge {
/* Used in the search results for layers */
display: flex;
align-items: center;
white-space: nowrap;
border-radius: 999rem;
padding-left: 0.25rem;
padding-right: 0.25rem;
border: 1px solid var(--low-interaction-border);
background-color: var(--low-interaction-background);
}
/************************* LEGACY MARKER - CLEANUP BELOW ********************************/
2021-11-25 21:31:33 +01:00
.animate-height {
/* Legacy: should be replaced by headlessui disclosure in time */
transition: max-height 0.5s ease-in-out;
overflow-y: hidden;
2021-11-25 21:31:33 +01:00
}
.min-h-32 {
min-height: 8rem;
}
2023-12-02 01:46:50 +01:00
.max-w-full {
max-width: 100%;
2024-04-24 02:44:31 +02:00
}
.max-h-leave-room {
/* Leaves room for a single button, with padding */
max-height: calc(100% - 3.25rem);
}
2024-08-29 03:53:54 +02:00
.max-w-screen {
max-width: 100vw;
}
2024-09-18 16:57:57 +02:00
.z-4 {
z-index: 4;
}
.z-3 {
z-index: 3;
}
.z-5 {
z-index: 5;
}
2024-04-24 02:44:31 +02:00
/************************* Experimental support for foldable devices ********************************/
@media (horizontal-viewport-segments: 2) {
.theme-list {
display: grid;
grid-auto-flow: row;
grid-template-columns: repeat(2, minmax(0, 1fr));
}
2023-12-02 01:46:50 +01:00
}