@zap-wunschlachen/wl-shared-components 1.0.37 → 1.0.38

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (257) hide show
  1. package/.github/workflows/playwright.yml +205 -205
  2. package/.github/workflows/static.yml +61 -61
  3. package/.github/workflows/update-snapshots.yml +37 -37
  4. package/.prettierrc +5 -5
  5. package/.storybook/main.ts +18 -18
  6. package/.storybook/preview.ts +37 -37
  7. package/.storybook/storyWrapper.vue +18 -18
  8. package/.storybook/withVuetifyTheme.decorator.ts +21 -21
  9. package/App.vue +33 -43
  10. package/README.md +56 -56
  11. package/heroicons.ts +75 -75
  12. package/index.html +19 -19
  13. package/package.json +67 -67
  14. package/playwright.config.ts +48 -48
  15. package/public/background.svg +60 -60
  16. package/public/style.css +187 -187
  17. package/public/technologies.svg +22 -22
  18. package/src/assets/css/base.css +232 -232
  19. package/src/assets/css/variables.css +109 -109
  20. package/src/components/Accordion/Accordion.css +59 -59
  21. package/src/components/Accordion/AccordionGroup.vue +51 -51
  22. package/src/components/Accordion/AccordionItem.vue +66 -66
  23. package/src/components/Appointment/Card/Actions.css +54 -54
  24. package/src/components/Appointment/Card/Actions.vue +99 -99
  25. package/src/components/Appointment/Card/AnamneseNotification.css +15 -15
  26. package/src/components/Appointment/Card/AnamneseNotification.vue +23 -23
  27. package/src/components/Appointment/Card/Card.css +80 -80
  28. package/src/components/Appointment/Card/Card.vue +93 -93
  29. package/src/components/Appointment/Card/Details.css +50 -50
  30. package/src/components/Appointment/Card/Details.vue +43 -43
  31. package/src/components/Audio/Audio.vue +187 -187
  32. package/src/components/Audio/Waveform.vue +118 -118
  33. package/src/components/Button/Button.vue +174 -174
  34. package/src/components/CheckBox/CheckBox.css +214 -214
  35. package/src/components/CheckBox/Checkbox.vue +138 -138
  36. package/src/components/DateInput/DateInput.css +2 -2
  37. package/src/components/DateInput/DateInput.vue +262 -262
  38. package/src/components/Dialog/Dialog.css +6 -6
  39. package/src/components/Dialog/Dialog.vue +38 -38
  40. package/src/components/EditField/EditField.css +19 -19
  41. package/src/components/EditField/EditField.vue +202 -202
  42. package/src/components/ErrorPage/ErrorPage.css +172 -172
  43. package/src/components/IconBullet/IconBullet.vue +86 -86
  44. package/src/components/IconBullet/IconBulletList.vue +41 -41
  45. package/src/components/Icons/AdvanceAppointments.vue +153 -153
  46. package/src/components/Icons/Audio/CloudFailed.vue +20 -20
  47. package/src/components/Icons/Audio/CloudSaved.vue +21 -21
  48. package/src/components/Icons/Audio/Delete.vue +15 -15
  49. package/src/components/Icons/Audio/Pause.vue +18 -18
  50. package/src/components/Icons/Audio/Play.vue +15 -15
  51. package/src/components/Icons/CalendarNotification.vue +126 -126
  52. package/src/components/Icons/Chair.vue +32 -32
  53. package/src/components/Icons/ChairNotification.vue +35 -35
  54. package/src/components/Icons/Circle.vue +66 -66
  55. package/src/components/Icons/FavIcon.vue +22 -22
  56. package/src/components/Icons/FilledCircle.vue +11 -11
  57. package/src/components/Icons/Group3.vue +46 -46
  58. package/src/components/Icons/RingNotification.vue +54 -54
  59. package/src/components/Icons/SolidArrowRight.vue +14 -14
  60. package/src/components/Icons/calendar.vue +17 -17
  61. package/src/components/Icons/checkbox.vue +19 -19
  62. package/src/components/Icons/outlineChecked.vue +27 -27
  63. package/src/components/Icons/play.vue +5 -5
  64. package/src/components/Input/Input.css +187 -187
  65. package/src/components/Input/Input.vue +253 -253
  66. package/src/components/Laboratory/AppointmentCard/AppointmentCard.css +7 -7
  67. package/src/components/Laboratory/AppointmentCard/AppointmentCard.vue +116 -116
  68. package/src/components/Laboratory/ChatBoxImage/ChatBoxImage.vue +81 -81
  69. package/src/components/Laboratory/ChatMessage/ChatMessage.vue +113 -113
  70. package/src/components/Laboratory/ChatMessage/ChatMessageBadge.css +4 -4
  71. package/src/components/Laboratory/ChatMessage/ChatMessageBadge.vue +99 -99
  72. package/src/components/Laboratory/ChatNotification/ChatNotification.vue +130 -130
  73. package/src/components/Laboratory/DocumentCard/DocumentCard.css +3 -3
  74. package/src/components/Laboratory/DocumentCard/DocumentCard.vue +50 -50
  75. package/src/components/Laboratory/DocumentCard/DocumentCardItem.vue +53 -53
  76. package/src/components/Laboratory/InfoCard/InfoCard.vue +162 -162
  77. package/src/components/Laboratory/MainColumnsBar/MainColumnsBar.vue +102 -102
  78. package/src/components/Laboratory/ProgressCircle/ProgressCircle.vue +152 -152
  79. package/src/components/Laboratory/ProgressLinear/ProgressLinear.css +33 -33
  80. package/src/components/Laboratory/ProgressLinear/ProgressLinear.vue +75 -75
  81. package/src/components/Laboratory/SelectionColumnBar/SelectionColumnBar.vue +92 -92
  82. package/src/components/Laboratory/StatusNotification/StatusNotification.vue +49 -49
  83. package/src/components/Laboratory/TagLabel/TagLabel.vue +126 -126
  84. package/src/components/Laboratory/TagLabelGroup/TagLabelGroup.vue +97 -97
  85. package/src/components/Laboratory/TicketCard/TicketCard.css +3 -3
  86. package/src/components/Laboratory/TicketCard/TicketCard.vue +143 -143
  87. package/src/components/Laboratory/TimeLine/TimeLineEvent.css +18 -18
  88. package/src/components/Laboratory/TimeLine/TimeLineEvent.vue +119 -119
  89. package/src/components/Laboratory/TimeLine/Timeline.css +4 -4
  90. package/src/components/Laboratory/TimeLine/Timeline.vue +30 -30
  91. package/src/components/Loader/Loader.css +71 -71
  92. package/src/components/MaintenanceBanner/MaintenanceBanner.css +353 -353
  93. package/src/components/MaintenanceBanner/MaintenanceBanner.vue +127 -127
  94. package/src/components/MaintenanceBanner/MaintenanceIllustration.vue +54 -54
  95. package/src/components/Modal/Modal.css +5 -5
  96. package/src/components/Modal/Modal.vue +22 -22
  97. package/src/components/NotificationBubble/NotificationBubble.css +4 -4
  98. package/src/components/NotificationBubble/NotificationBubble.vue +90 -90
  99. package/src/components/OtpInput/OtpInput.css +39 -39
  100. package/src/components/OtpInput/OtpInput.vue +151 -151
  101. package/src/components/PhoneInput/PhoneInput.css +31 -31
  102. package/src/components/PhoneInput/PhoneInput.vue +113 -113
  103. package/src/components/Select/Select.css +150 -150
  104. package/src/components/Select/Select.vue +316 -316
  105. package/src/components/StagingBanner/StagingBanner.css +19 -0
  106. package/src/components/StagingBanner/StagingBanner.vue +82 -0
  107. package/src/components/TextArea/TextArea.css +3 -3
  108. package/src/components/TextArea/TextArea.vue +126 -126
  109. package/src/components/TickBox/TickBox.css +49 -49
  110. package/src/components/TickBox/TickBox.vue +126 -126
  111. package/src/components/accessibility.css +218 -218
  112. package/src/components/index.ts +29 -28
  113. package/src/constants/iconEnums.ts +3 -3
  114. package/src/i18n/i18n.ts +15 -15
  115. package/src/i18n/locales/de.json +30 -30
  116. package/src/i18n/locales/en.json +30 -30
  117. package/src/index.ts +34 -34
  118. package/src/main.ts +11 -11
  119. package/src/plugins/vuetify.ts +141 -141
  120. package/src/shims-vue.d.ts +10 -10
  121. package/src/stories/Accordion.stories.ts +650 -650
  122. package/src/stories/Audio.stories.ts +28 -28
  123. package/src/stories/Button.stories.ts +263 -263
  124. package/src/stories/CheckBox.stories.ts +348 -348
  125. package/src/stories/DateInput.stories.ts +53 -53
  126. package/src/stories/Dialog.stories.ts +147 -147
  127. package/src/stories/EditField.stories.ts +78 -78
  128. package/src/stories/IconBullet/IconBullet.stories.ts +201 -201
  129. package/src/stories/IconBullet/IconBulletList.stories.ts +275 -275
  130. package/src/stories/Input.stories.ts +351 -351
  131. package/src/stories/Laboratory/Cards/AppointmentCard/AppointmentCard.stories.ts +260 -260
  132. package/src/stories/Laboratory/Cards/DocumentCard/DocumentCard.stories.ts +176 -176
  133. package/src/stories/Laboratory/Cards/DocumentCard/DocumentCardItem.stories.ts +119 -119
  134. package/src/stories/Laboratory/Cards/InfoCard/InfoCard.stories.ts +320 -320
  135. package/src/stories/Laboratory/Cards/TicketCard/TicketCard.stories.ts +335 -335
  136. package/src/stories/Laboratory/Chat/ChatBoxImage.stories.ts +82 -82
  137. package/src/stories/Laboratory/Chat/ChatMessage.stories.ts +198 -198
  138. package/src/stories/Laboratory/Chat/ChatMessageBadge.stories.ts +204 -204
  139. package/src/stories/Laboratory/Chat/ChatNotification.stories.ts +144 -144
  140. package/src/stories/Laboratory/Chat/ProgressLinear.stories.ts +186 -186
  141. package/src/stories/Laboratory/Chat/StatusNotification.stories.ts +111 -111
  142. package/src/stories/Laboratory/MainColumnsBar.stories.ts +48 -48
  143. package/src/stories/Laboratory/ProgressCircle.stories.ts +261 -261
  144. package/src/stories/Laboratory/SelectionColumnBar.stories.ts +234 -234
  145. package/src/stories/Laboratory/TagLabel.stories.ts +418 -418
  146. package/src/stories/Laboratory/TagLabelGroup.stories.ts +234 -234
  147. package/src/stories/Laboratory/Timeline.stories.ts +403 -403
  148. package/src/stories/NotificationBubble.stories.ts +194 -194
  149. package/src/stories/OtpInput.stories.ts +100 -100
  150. package/src/stories/PhoneInput.stories.ts +52 -52
  151. package/src/stories/Select.stories.ts +419 -419
  152. package/src/stories/TextArea.stories.ts +112 -112
  153. package/src/stories/TickBox.stories.ts +294 -294
  154. package/src/stories/v-icon.stories.ts +91 -91
  155. package/src/utils/index.ts +109 -109
  156. package/src/vite-env.d.ts +1 -1
  157. package/tests/e2e/README.md +220 -220
  158. package/tests/e2e/accessibility.spec.ts +638 -638
  159. package/tests/e2e/accordion.spec.ts +42 -42
  160. package/tests/e2e/additional-components.spec.ts +437 -437
  161. package/tests/e2e/all-components.spec.ts +135 -135
  162. package/tests/e2e/appointment-card.spec.ts +816 -816
  163. package/tests/e2e/button-fixed.spec.ts +58 -58
  164. package/tests/e2e/button.spec.ts +76 -76
  165. package/tests/e2e/checkbox.spec.ts +50 -50
  166. package/tests/e2e/date-input.spec.ts +46 -46
  167. package/tests/e2e/debug.spec.ts +51 -51
  168. package/tests/e2e/dialog.spec.ts +58 -58
  169. package/tests/e2e/input.spec.ts +55 -55
  170. package/tests/e2e/laboratory-components.spec.ts +320 -320
  171. package/tests/e2e/otp-input.spec.ts +50 -50
  172. package/tests/e2e/select.spec.ts +52 -52
  173. package/tests/e2e/storybook-utils.ts +59 -59
  174. package/tests/e2e/test-basic.spec.ts +33 -33
  175. package/tests/e2e/visual-regression.spec.ts +350 -350
  176. package/tests/unit/accessibility/component-a11y.spec.ts +469 -469
  177. package/tests/unit/components/Accordion/AccordionGroup.spec.ts +228 -228
  178. package/tests/unit/components/Accordion/AccordionGroup.spec.ts.skip +342 -342
  179. package/tests/unit/components/Accordion/AccordionItem.spec.ts +292 -292
  180. package/tests/unit/components/Accordion/AccordionItem.spec.ts.skip +383 -383
  181. package/tests/unit/components/Appointment/AnamneseNotification.spec.ts +176 -176
  182. package/tests/unit/components/Appointment/Card/Actions.spec.ts +407 -407
  183. package/tests/unit/components/Appointment/Card/Card.spec.ts +485 -485
  184. package/tests/unit/components/Appointment/Card/Details.spec.ts +397 -397
  185. package/tests/unit/components/Audio/Audio.spec.ts +403 -403
  186. package/tests/unit/components/Audio/Waveform.spec.ts +483 -483
  187. package/tests/unit/components/Background/Background.spec.ts +177 -177
  188. package/tests/unit/components/Core/Button.spec.ts +336 -336
  189. package/tests/unit/components/Core/Checkbox.spec.ts +544 -544
  190. package/tests/unit/components/Core/DateInput.spec.ts +690 -690
  191. package/tests/unit/components/Core/Dialog.spec.ts +485 -485
  192. package/tests/unit/components/Core/EditField.spec.ts +782 -782
  193. package/tests/unit/components/Core/Input.spec.ts +512 -512
  194. package/tests/unit/components/Core/Modal.spec.ts +518 -518
  195. package/tests/unit/components/Core/NotificationBubble.spec.ts +606 -606
  196. package/tests/unit/components/Core/OtpInput.spec.ts +708 -708
  197. package/tests/unit/components/Core/PhoneInput.spec.ts +619 -619
  198. package/tests/unit/components/Core/Select.spec.ts +712 -712
  199. package/tests/unit/components/Core/TextArea.spec.ts +565 -565
  200. package/tests/unit/components/Core/TickBox.spec.ts +779 -779
  201. package/tests/unit/components/ErrorPage/ErrorPage.spec.ts +313 -313
  202. package/tests/unit/components/ErrorPage/ErrorPageLogo.spec.ts +153 -153
  203. package/tests/unit/components/IconBullet/IconBullet.spec.ts +356 -356
  204. package/tests/unit/components/IconBullet/IconBulletList.spec.ts +371 -371
  205. package/tests/unit/components/Icons/AdvanceAppointments.spec.ts +61 -61
  206. package/tests/unit/components/Icons/Audio/CloudFailed.spec.ts +108 -108
  207. package/tests/unit/components/Icons/Audio/CloudSaved.spec.ts +149 -149
  208. package/tests/unit/components/Icons/Audio/Delete.spec.ts +158 -158
  209. package/tests/unit/components/Icons/Audio/Pause.spec.ts +208 -208
  210. package/tests/unit/components/Icons/Audio/Play.spec.ts +217 -217
  211. package/tests/unit/components/Icons/CalendarNotification.spec.ts +186 -186
  212. package/tests/unit/components/Icons/Chair.spec.ts +234 -234
  213. package/tests/unit/components/Icons/ChairNotification.spec.ts +311 -311
  214. package/tests/unit/components/Icons/Circle.spec.ts +255 -255
  215. package/tests/unit/components/Icons/FavIcon.spec.ts +251 -251
  216. package/tests/unit/components/Icons/FilledCircle.spec.ts +274 -274
  217. package/tests/unit/components/Icons/Group3.spec.ts +355 -355
  218. package/tests/unit/components/Icons/Logo.spec.ts +228 -228
  219. package/tests/unit/components/Icons/MiniLogo.spec.ts +38 -38
  220. package/tests/unit/components/Icons/RingNotification.spec.ts +393 -393
  221. package/tests/unit/components/Icons/SolidArrowRight.spec.ts +49 -49
  222. package/tests/unit/components/Icons/calendar.spec.ts +286 -286
  223. package/tests/unit/components/Icons/checkbox.spec.ts +315 -315
  224. package/tests/unit/components/Icons/outlineChecked.spec.ts +434 -434
  225. package/tests/unit/components/Icons/play.spec.ts +308 -308
  226. package/tests/unit/components/Laboratory/AppointmentCard.spec.ts +167 -167
  227. package/tests/unit/components/Laboratory/ChatBoxImage.spec.ts +179 -179
  228. package/tests/unit/components/Laboratory/ChatMessage.spec.ts +263 -263
  229. package/tests/unit/components/Laboratory/ChatMessageBadge.spec.ts +282 -282
  230. package/tests/unit/components/Laboratory/ChatNotification.spec.ts +256 -256
  231. package/tests/unit/components/Laboratory/DocumentCard.spec.ts +228 -228
  232. package/tests/unit/components/Laboratory/DocumentCardItem.spec.ts +236 -236
  233. package/tests/unit/components/Laboratory/InfoCard.spec.ts +308 -308
  234. package/tests/unit/components/Laboratory/MainColumnsBar.spec.ts +251 -251
  235. package/tests/unit/components/Laboratory/ProgressCircle.spec.ts +290 -290
  236. package/tests/unit/components/Laboratory/ProgressLinear.spec.ts +275 -275
  237. package/tests/unit/components/Laboratory/SelectionColumnBar.spec.ts +288 -288
  238. package/tests/unit/components/Laboratory/StatusNotification.spec.ts +296 -296
  239. package/tests/unit/components/Laboratory/TagLabel.spec.ts +353 -353
  240. package/tests/unit/components/Laboratory/TagLabelGroup.spec.ts +377 -377
  241. package/tests/unit/components/Laboratory/TicketCard.spec.ts +351 -351
  242. package/tests/unit/components/Laboratory/TimeLineEvent.spec.ts +381 -381
  243. package/tests/unit/components/Laboratory/Timeline.spec.ts +419 -419
  244. package/tests/unit/components/Loader/Loader.spec.ts +197 -197
  245. package/tests/unit/components/MaintenanceBanner/MaintenanceBanner.spec.ts +302 -302
  246. package/tests/unit/constants/iconEnums.spec.ts +39 -39
  247. package/tests/unit/i18n/i18n.spec.ts +88 -88
  248. package/tests/unit/plugins/vuetify.spec.ts +220 -220
  249. package/tests/unit/setup.ts +189 -189
  250. package/tests/unit/src/components/index.spec.ts.skip +192 -192
  251. package/tests/unit/src/index.spec.ts.skip +182 -182
  252. package/tests/unit/src/main.spec.ts +151 -151
  253. package/tests/unit/utils/accessibility.spec.ts +318 -318
  254. package/tsconfig.json +26 -26
  255. package/vite.config.ts +29 -29
  256. package/vitest.config.ts +83 -83
  257. package/public/audio/test.aac +0 -0
@@ -1,353 +1,353 @@
1
- /* Cocoon variant - centered layout without illustration */
2
- .maintenance-banner__content--cocoon {
3
- justify-content: center;
4
- max-width: 930px;
5
- }
6
-
7
- .maintenance-banner__content--cocoon .maintenance-banner__text-content {
8
- align-items: flex-start;
9
- text-align: left;
10
- max-width: 100%;
11
- }
12
-
13
- .maintenance-banner__content--cocoon .maintenance-banner__logo-section {
14
- align-items: flex-start;
15
- }
16
-
17
- .maintenance-banner__content--cocoon .maintenance-banner__logo-headline {
18
- align-items: flex-start;
19
- }
20
-
21
- .maintenance-banner__content--cocoon .maintenance-banner__title {
22
- text-align: left;
23
- }
24
-
25
- .maintenance-banner__content--cocoon .maintenance-banner__body-section {
26
- align-items: flex-start;
27
- }
28
-
29
- .maintenance-banner__content--cocoon .maintenance-banner__description {
30
- text-align: left;
31
- }
32
-
33
- .maintenance-banner__content--cocoon .maintenance-banner__contact {
34
- align-items: flex-start;
35
- }
36
-
37
- /* Background Logo */
38
- .maintenance-banner__bg-logo {
39
- position: absolute;
40
- left: -823px;
41
- top: -527px;
42
- width: 2067px;
43
- height: 2067px;
44
- opacity: 0.6;
45
- pointer-events: none;
46
- }
47
-
48
- .maintenance-banner__bg-logo svg {
49
- width: 100%;
50
- height: 100%;
51
- }
52
-
53
- /* Main Content */
54
- .maintenance-banner__content {
55
- display: flex;
56
- flex-direction: row;
57
- align-items: center;
58
- justify-content: flex-end;
59
- gap: 92px;
60
- max-width: 930px;
61
- width: 100%;
62
- padding: 2rem;
63
- position: relative;
64
- z-index: 1;
65
- }
66
-
67
- /* Illustration */
68
- .maintenance-banner__illustration {
69
- flex-shrink: 0;
70
- width: 304px;
71
- height: 304px;
72
- }
73
-
74
- .maintenance-banner__illustration svg {
75
- width: 100%;
76
- height: 100%;
77
- }
78
-
79
- /* Text Content */
80
- .maintenance-banner__text-content {
81
- display: flex;
82
- flex-direction: column;
83
- gap: 48px;
84
- max-width: 455px;
85
- width: 100%;
86
- }
87
-
88
- .maintenance-banner__logo-section {
89
- display: flex;
90
- flex-direction: column;
91
- gap: 32px;
92
- width: 100%;
93
- }
94
-
95
- .maintenance-banner__logo-headline {
96
- display: flex;
97
- flex-direction: column;
98
- gap: 32px;
99
- width: 100%;
100
- }
101
-
102
- /* Title */
103
- .maintenance-banner__title {
104
- font-family: 'Outfit', sans-serif;
105
- font-weight: 700;
106
- font-size: 65px;
107
- line-height: 1.2;
108
- letter-spacing: -0.02em;
109
- margin: 0;
110
- }
111
-
112
- /* Body Section */
113
- .maintenance-banner__body-section {
114
- display: flex;
115
- flex-direction: column;
116
- gap: 24px;
117
- width: 100%;
118
- }
119
-
120
- /* Description */
121
- .maintenance-banner__description {
122
- font-weight: 300;
123
- font-size: 20px;
124
- line-height: 1.2;
125
- letter-spacing: 0.05em;
126
- margin: 0;
127
- white-space: pre-line;
128
- overflow: visible;
129
- text-overflow: unset;
130
- display: block;
131
- }
132
-
133
- /* Contact Info */
134
- .maintenance-banner__contact {
135
- display: flex;
136
- flex-direction: column;
137
- gap: 8px;
138
- }
139
-
140
- .maintenance-banner__contact-item {
141
- display: flex;
142
- flex-direction: row;
143
- align-items: center;
144
- justify-content: flex-start;
145
- gap: 10px;
146
- }
147
-
148
- .maintenance-banner__icon {
149
- width: 24px;
150
- height: 24px;
151
- flex-shrink: 0;
152
- }
153
-
154
- .maintenance-banner__contact-text {
155
- font-family: 'Outfit', sans-serif;
156
- font-weight: 300;
157
- font-size: 20px;
158
- line-height: 1.2;
159
- letter-spacing: 0.05em;
160
- }
161
-
162
- /* CTA Button */
163
- .maintenance-banner__button {
164
- display: flex;
165
- align-items: center;
166
- justify-content: center;
167
- gap: 8px;
168
- padding: 16px 32px;
169
- width: 309px;
170
- height: 48px;
171
- border-radius: 8px;
172
- background: transparent;
173
- font-family: 'Outfit', sans-serif;
174
- font-weight: 300;
175
- font-size: 20px;
176
- line-height: 1.2;
177
- letter-spacing: 0.05em;
178
- text-decoration: none;
179
- cursor: pointer;
180
- transition: background-color 0.2s ease, color 0.2s ease;
181
- box-sizing: border-box;
182
- }
183
-
184
- .maintenance-banner__button:hover {
185
- color: #FFFFFF;
186
- }
187
-
188
- .maintenance-banner__button:focus-visible {
189
- outline: 2px solid currentColor;
190
- outline-offset: 2px;
191
- }
192
-
193
- .maintenance-banner__button:focus-visible {
194
- outline: 2px solid currentColor;
195
- outline-offset: 2px;
196
- }
197
-
198
- /* Responsive Design */
199
- @media (max-width: 1024px) {
200
- .maintenance-banner__content {
201
- flex-direction: column;
202
- gap: 48px;
203
- justify-content: center;
204
- align-items: center;
205
- padding: 2rem 1.5rem;
206
- }
207
-
208
- .maintenance-banner__illustration {
209
- width: 200px;
210
- height: 200px;
211
- }
212
-
213
- .maintenance-banner__text-content {
214
- max-width: 100%;
215
- align-items: center;
216
- text-align: center;
217
- }
218
-
219
- .maintenance-banner__logo-section {
220
- align-items: center;
221
- }
222
-
223
- .maintenance-banner__logo-headline {
224
- align-items: center;
225
- }
226
-
227
- .maintenance-banner__title {
228
- font-size: 40px;
229
- text-align: center;
230
- }
231
-
232
- .maintenance-banner__body-section {
233
- align-items: center;
234
- }
235
-
236
- .maintenance-banner__description {
237
- text-align: center;
238
- }
239
-
240
- .maintenance-banner__contact {
241
- align-items: center;
242
- }
243
-
244
- .maintenance-banner__button {
245
- width: 100%;
246
- max-width: 309px;
247
- }
248
-
249
- .maintenance-banner__bg-logo {
250
- left: -1000px;
251
- top: -800px;
252
- }
253
- }
254
-
255
- @media (max-width: 480px) {
256
- .maintenance-banner__title {
257
- font-size: 32px;
258
- }
259
-
260
- .maintenance-banner__description,
261
- .maintenance-banner__contact-text {
262
- font-size: 16px;
263
- }
264
-
265
- .maintenance-banner__illustration {
266
- width: 150px;
267
- height: 150px;
268
- }
269
-
270
- .maintenance-banner__button {
271
- font-size: 16px;
272
- padding: 12px 24px;
273
- height: auto;
274
- }
275
- }
276
-
277
- /* Small mobile screens with limited height (e.g. iPhone SE) */
278
- @media (max-width: 480px) and (max-height: 700px) {
279
- .maintenance-banner__content {
280
- gap: 24px;
281
- padding: 1rem;
282
- }
283
-
284
- .maintenance-banner__text-content {
285
- gap: 24px;
286
- }
287
-
288
- .maintenance-banner__logo-section {
289
- gap: 16px;
290
- }
291
-
292
- .maintenance-banner__logo-headline {
293
- gap: 16px;
294
- }
295
-
296
- .maintenance-banner__body-section {
297
- gap: 12px;
298
- }
299
-
300
- .maintenance-banner__illustration {
301
- width: 100px;
302
- height: 100px;
303
- }
304
-
305
- .maintenance-banner__title {
306
- font-size: 24px;
307
- }
308
-
309
- .maintenance-banner__description,
310
- .maintenance-banner__contact-text {
311
- font-size: 14px;
312
- }
313
-
314
- .maintenance-banner__button {
315
- font-size: 14px;
316
- padding: 10px 20px;
317
- height: auto;
318
- width: auto;
319
- }
320
- }
321
-
322
- @media (max-width: 480px) and (max-height: 600px) {
323
- .maintenance-banner__illustration {
324
- display: none;
325
- }
326
-
327
- .maintenance-banner__title {
328
- font-size: 22px;
329
- }
330
-
331
- .maintenance-banner__content {
332
- gap: 16px;
333
- padding: 0.5rem;
334
- }
335
-
336
- .maintenance-banner__text-content {
337
- gap: 16px;
338
- }
339
- }
340
-
341
- /* Respect users who prefer reduced motion: disable transitions/animations */
342
- @media (prefers-reduced-motion: reduce) {
343
- .maintenance-banner__button,
344
- .maintenance-banner__button:hover,
345
- .maintenance-banner__content,
346
- .maintenance-banner__illustration,
347
- .maintenance-banner__bg-logo,
348
- .maintenance-banner__logo-headline,
349
- .maintenance-banner__logo-section {
350
- transition: none !important;
351
- animation: none !important;
352
- }
353
- }
1
+ /* Cocoon variant - centered layout without illustration */
2
+ .maintenance-banner__content--cocoon {
3
+ justify-content: center;
4
+ max-width: 930px;
5
+ }
6
+
7
+ .maintenance-banner__content--cocoon .maintenance-banner__text-content {
8
+ align-items: flex-start;
9
+ text-align: left;
10
+ max-width: 100%;
11
+ }
12
+
13
+ .maintenance-banner__content--cocoon .maintenance-banner__logo-section {
14
+ align-items: flex-start;
15
+ }
16
+
17
+ .maintenance-banner__content--cocoon .maintenance-banner__logo-headline {
18
+ align-items: flex-start;
19
+ }
20
+
21
+ .maintenance-banner__content--cocoon .maintenance-banner__title {
22
+ text-align: left;
23
+ }
24
+
25
+ .maintenance-banner__content--cocoon .maintenance-banner__body-section {
26
+ align-items: flex-start;
27
+ }
28
+
29
+ .maintenance-banner__content--cocoon .maintenance-banner__description {
30
+ text-align: left;
31
+ }
32
+
33
+ .maintenance-banner__content--cocoon .maintenance-banner__contact {
34
+ align-items: flex-start;
35
+ }
36
+
37
+ /* Background Logo */
38
+ .maintenance-banner__bg-logo {
39
+ position: absolute;
40
+ left: -823px;
41
+ top: -527px;
42
+ width: 2067px;
43
+ height: 2067px;
44
+ opacity: 0.6;
45
+ pointer-events: none;
46
+ }
47
+
48
+ .maintenance-banner__bg-logo svg {
49
+ width: 100%;
50
+ height: 100%;
51
+ }
52
+
53
+ /* Main Content */
54
+ .maintenance-banner__content {
55
+ display: flex;
56
+ flex-direction: row;
57
+ align-items: center;
58
+ justify-content: flex-end;
59
+ gap: 92px;
60
+ max-width: 930px;
61
+ width: 100%;
62
+ padding: 2rem;
63
+ position: relative;
64
+ z-index: 1;
65
+ }
66
+
67
+ /* Illustration */
68
+ .maintenance-banner__illustration {
69
+ flex-shrink: 0;
70
+ width: 304px;
71
+ height: 304px;
72
+ }
73
+
74
+ .maintenance-banner__illustration svg {
75
+ width: 100%;
76
+ height: 100%;
77
+ }
78
+
79
+ /* Text Content */
80
+ .maintenance-banner__text-content {
81
+ display: flex;
82
+ flex-direction: column;
83
+ gap: 48px;
84
+ max-width: 455px;
85
+ width: 100%;
86
+ }
87
+
88
+ .maintenance-banner__logo-section {
89
+ display: flex;
90
+ flex-direction: column;
91
+ gap: 32px;
92
+ width: 100%;
93
+ }
94
+
95
+ .maintenance-banner__logo-headline {
96
+ display: flex;
97
+ flex-direction: column;
98
+ gap: 32px;
99
+ width: 100%;
100
+ }
101
+
102
+ /* Title */
103
+ .maintenance-banner__title {
104
+ font-family: 'Outfit', sans-serif;
105
+ font-weight: 700;
106
+ font-size: 65px;
107
+ line-height: 1.2;
108
+ letter-spacing: -0.02em;
109
+ margin: 0;
110
+ }
111
+
112
+ /* Body Section */
113
+ .maintenance-banner__body-section {
114
+ display: flex;
115
+ flex-direction: column;
116
+ gap: 24px;
117
+ width: 100%;
118
+ }
119
+
120
+ /* Description */
121
+ .maintenance-banner__description {
122
+ font-weight: 300;
123
+ font-size: 20px;
124
+ line-height: 1.2;
125
+ letter-spacing: 0.05em;
126
+ margin: 0;
127
+ white-space: pre-line;
128
+ overflow: visible;
129
+ text-overflow: unset;
130
+ display: block;
131
+ }
132
+
133
+ /* Contact Info */
134
+ .maintenance-banner__contact {
135
+ display: flex;
136
+ flex-direction: column;
137
+ gap: 8px;
138
+ }
139
+
140
+ .maintenance-banner__contact-item {
141
+ display: flex;
142
+ flex-direction: row;
143
+ align-items: center;
144
+ justify-content: flex-start;
145
+ gap: 10px;
146
+ }
147
+
148
+ .maintenance-banner__icon {
149
+ width: 24px;
150
+ height: 24px;
151
+ flex-shrink: 0;
152
+ }
153
+
154
+ .maintenance-banner__contact-text {
155
+ font-family: 'Outfit', sans-serif;
156
+ font-weight: 300;
157
+ font-size: 20px;
158
+ line-height: 1.2;
159
+ letter-spacing: 0.05em;
160
+ }
161
+
162
+ /* CTA Button */
163
+ .maintenance-banner__button {
164
+ display: flex;
165
+ align-items: center;
166
+ justify-content: center;
167
+ gap: 8px;
168
+ padding: 16px 32px;
169
+ width: 309px;
170
+ height: 48px;
171
+ border-radius: 8px;
172
+ background: transparent;
173
+ font-family: 'Outfit', sans-serif;
174
+ font-weight: 300;
175
+ font-size: 20px;
176
+ line-height: 1.2;
177
+ letter-spacing: 0.05em;
178
+ text-decoration: none;
179
+ cursor: pointer;
180
+ transition: background-color 0.2s ease, color 0.2s ease;
181
+ box-sizing: border-box;
182
+ }
183
+
184
+ .maintenance-banner__button:hover {
185
+ color: #FFFFFF;
186
+ }
187
+
188
+ .maintenance-banner__button:focus-visible {
189
+ outline: 2px solid currentColor;
190
+ outline-offset: 2px;
191
+ }
192
+
193
+ .maintenance-banner__button:focus-visible {
194
+ outline: 2px solid currentColor;
195
+ outline-offset: 2px;
196
+ }
197
+
198
+ /* Responsive Design */
199
+ @media (max-width: 1024px) {
200
+ .maintenance-banner__content {
201
+ flex-direction: column;
202
+ gap: 48px;
203
+ justify-content: center;
204
+ align-items: center;
205
+ padding: 2rem 1.5rem;
206
+ }
207
+
208
+ .maintenance-banner__illustration {
209
+ width: 200px;
210
+ height: 200px;
211
+ }
212
+
213
+ .maintenance-banner__text-content {
214
+ max-width: 100%;
215
+ align-items: center;
216
+ text-align: center;
217
+ }
218
+
219
+ .maintenance-banner__logo-section {
220
+ align-items: center;
221
+ }
222
+
223
+ .maintenance-banner__logo-headline {
224
+ align-items: center;
225
+ }
226
+
227
+ .maintenance-banner__title {
228
+ font-size: 40px;
229
+ text-align: center;
230
+ }
231
+
232
+ .maintenance-banner__body-section {
233
+ align-items: center;
234
+ }
235
+
236
+ .maintenance-banner__description {
237
+ text-align: center;
238
+ }
239
+
240
+ .maintenance-banner__contact {
241
+ align-items: center;
242
+ }
243
+
244
+ .maintenance-banner__button {
245
+ width: 100%;
246
+ max-width: 309px;
247
+ }
248
+
249
+ .maintenance-banner__bg-logo {
250
+ left: -1000px;
251
+ top: -800px;
252
+ }
253
+ }
254
+
255
+ @media (max-width: 480px) {
256
+ .maintenance-banner__title {
257
+ font-size: 32px;
258
+ }
259
+
260
+ .maintenance-banner__description,
261
+ .maintenance-banner__contact-text {
262
+ font-size: 16px;
263
+ }
264
+
265
+ .maintenance-banner__illustration {
266
+ width: 150px;
267
+ height: 150px;
268
+ }
269
+
270
+ .maintenance-banner__button {
271
+ font-size: 16px;
272
+ padding: 12px 24px;
273
+ height: auto;
274
+ }
275
+ }
276
+
277
+ /* Small mobile screens with limited height (e.g. iPhone SE) */
278
+ @media (max-width: 480px) and (max-height: 700px) {
279
+ .maintenance-banner__content {
280
+ gap: 24px;
281
+ padding: 1rem;
282
+ }
283
+
284
+ .maintenance-banner__text-content {
285
+ gap: 24px;
286
+ }
287
+
288
+ .maintenance-banner__logo-section {
289
+ gap: 16px;
290
+ }
291
+
292
+ .maintenance-banner__logo-headline {
293
+ gap: 16px;
294
+ }
295
+
296
+ .maintenance-banner__body-section {
297
+ gap: 12px;
298
+ }
299
+
300
+ .maintenance-banner__illustration {
301
+ width: 100px;
302
+ height: 100px;
303
+ }
304
+
305
+ .maintenance-banner__title {
306
+ font-size: 24px;
307
+ }
308
+
309
+ .maintenance-banner__description,
310
+ .maintenance-banner__contact-text {
311
+ font-size: 14px;
312
+ }
313
+
314
+ .maintenance-banner__button {
315
+ font-size: 14px;
316
+ padding: 10px 20px;
317
+ height: auto;
318
+ width: auto;
319
+ }
320
+ }
321
+
322
+ @media (max-width: 480px) and (max-height: 600px) {
323
+ .maintenance-banner__illustration {
324
+ display: none;
325
+ }
326
+
327
+ .maintenance-banner__title {
328
+ font-size: 22px;
329
+ }
330
+
331
+ .maintenance-banner__content {
332
+ gap: 16px;
333
+ padding: 0.5rem;
334
+ }
335
+
336
+ .maintenance-banner__text-content {
337
+ gap: 16px;
338
+ }
339
+ }
340
+
341
+ /* Respect users who prefer reduced motion: disable transitions/animations */
342
+ @media (prefers-reduced-motion: reduce) {
343
+ .maintenance-banner__button,
344
+ .maintenance-banner__button:hover,
345
+ .maintenance-banner__content,
346
+ .maintenance-banner__illustration,
347
+ .maintenance-banner__bg-logo,
348
+ .maintenance-banner__logo-headline,
349
+ .maintenance-banner__logo-section {
350
+ transition: none !important;
351
+ animation: none !important;
352
+ }
353
+ }