aboutsummaryrefslogtreecommitdiff
path: root/viewer/src/assets/scss/global.scss
blob: 0a2f8f0a7186925bc0b328ab0b8abaed76308881 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
/* ldgallery - A static generator which turns a collection of tagged
--             pictures into a searchable web gallery.
--
-- Copyright (C) 2019-2022  Guillaume FOUET
--
-- This program is free software: you can redistribute it and/or modify
-- it under the terms of the GNU Affero General Public License as
-- published by the Free Software Foundation, either version 3 of the
-- License, or (at your option) any later version.
--
-- This program is distributed in the hope that it will be useful,
-- but WITHOUT ANY WARRANTY; without even the implied warranty of
-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-- GNU Affero General Public License for more details.
--
-- You should have received a copy of the GNU Affero General Public License
-- along with this program.  If not, see <https://www.gnu.org/licenses/>.
*/

// Global CSS
@import "theme";

h1 {
  font-size: $size-5;
  font-weight: $weight-semibold;
  line-height: 1.125;
}
h2 {
  font-size: $size-6;
  font-weight: $weight-normal;
}

// === Forms

button {
  cursor: pointer;
  color: $button-color;
  background-color: $button-background-color;
  border: 1px solid $button-border-color;
  padding: calc(0.375em - 1px) 0.75em;
  font-family: inherit;
  line-height: 1.5;
  font-size: $size-6;
  &:hover,&:focus {
    border-color: $button-active-color;
    outline: none;
  }
}

// === Tools

.no-scroll {
  overflow: hidden;
}
.no-scroll-x {
  overflow-x: hidden;
}

.flex {
  display: flex;
}
.flex-column {
  display: flex;
  flex-direction: column;
}
.flex-center {
  align-items: center;
}
.flex-grow-1 {
  flex-grow: 1;
}

.fill {
  width: 100%;
  height: 100%;
}

/**
 * Class for containers that centers its content vertically and horizontally,
 * preferably sticking to the container start if the container is smaller than the content.
 */
.container-vh-centering {
  min-height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

// === Links

.disabled {
  color: $disabled-color !important;
  cursor: initial;
}

// Disable sticky hover styling on touch devices,
// on which the virtual cursor doesn't leave the element after being tapped.
// The fix can be applied to `a` elements by using the .link class.
@media (hover: none), (hover: on-demand) {
  .link:hover {
    color: $link !important;
  }
  .disabled:hover {
    color: $disabled-color !important;
  }
}

// === Effect to apply on lazy-image loading

img {
  display: block;
  image-orientation: from-image;
  &.v-lazy-image {
    opacity: 0;
    transition: opacity 0.4s;
  }
  &.v-lazy-image-loaded {
    opacity: 1;
  }
}