]> code.citadel.org Git - citadel.git/blob - webcit-ng/static/css/webcit.css
8bda814ff0d212f133f4b37fb14eab69859dfd20
[citadel.git] / webcit-ng / static / css / webcit.css
1 /*
2         Copyright (c) 1996-2023 by Art Cancro and the citadel.org team.
3         This program is open source software.  Use, duplication, or disclosure
4         are subject to the terms of the GNU General Public License, version 3.
5 */
6
7 * {                                             /* This makes grids consume exactly 100% of their parent containers */
8         box-sizing: border-box;
9         padding: 0;
10         margin: 0;
11 }
12
13 [contenteditable]:focus {
14         outline: 0px solid transparent;
15
16
17 .ctdl-main-grid-container {                     /* This grid implements the "holy grail layout" of the screen */
18         display: grid;
19         grid-template-rows: 5vh auto;
20         grid-template-columns: 12vw auto;
21         grid-template-areas:
22                 'ctdl-mg-banner ctdl-mg-banner'
23                 'ctdl-mg-menu ctdl-mg-main';
24         gap: 1px;                               /* This is the thickness of the lines between the boxes */
25         background-color: DarkSlateGrey;        /* This is the color of the lines between the boxes */
26         padding: 0;                             /* This is the border around the edges of the screen (0 for no border) */
27         width: 100vw;
28         height: 100vh;
29 }
30
31 .ctdl-grid-banner-item {                        /* Top banner, referenced by the grid container */
32         grid-area: ctdl-mg-banner;
33         background-color: DarkSlateGrey;
34 }
35
36 .ctdl-grid-sidebar-item {                       /* Side bar, referenced by the grid container */
37         grid-area: ctdl-mg-menu;
38         background-color: GhostWhite;
39 }
40
41 .ctdl-grid-main-item {                          /* Main content area of the screen, referenced by the grid container */
42         grid-area: ctdl-mg-main;
43         overflow-x: hidden;
44         overflow-y: auto;
45         background-color: GhostWhite;
46 }
47
48 .ctdl-main-grid-container > div {
49         text-align: left;
50 }
51
52 .ctdl-banner-buttons {                          /* Flexbox container for everything we stick into the banner */
53         display: flex;
54         flex-direction: row;
55         flex-wrap: nowrap;
56         justify-content: space-between;
57         align-items: center;
58         margin: 0;
59         width: 100%;
60         height: 100%;
61         overflow: hidden;
62 }
63
64 .ctdl-banner-left {                             /* Items which should be grouped to the LEFT side of the banner */
65         display: flex;
66         flex-direction: row;
67         flex-wrap: nowrap;
68         align-items: center;
69 }
70
71 .ctdl-banner-center {                           /* Items which should be grouped to the MIDDLE of the banner */
72         display: flex;
73         flex-direction: row;
74         flex-wrap: nowrap;
75         align-items: center;
76 }
77
78 .ctdl-banner-right {                            /* Items which should be grouped to the RIGHT side of the banner */
79         display: flex;
80         flex-direction: row;
81         flex-wrap: nowrap;
82         align-items: center;
83 }
84
85 .ctdl-banner-buttons li, .ctdl-banner-buttons li button {
86         float: left;
87         display: block;
88         background-color: DarkSlateGrey;
89         color: White;
90         font-size: 1.7vh;
91         border: none;
92         padding: 1vh;
93 }
94
95 .ctdl-banner-buttons li button:hover {
96         background-color: Black;
97 }
98
99 .ctdl-banner-buttons a {                        /* For example, the Login / Log Off button */
100         color: White;
101 }
102
103 .ctdl-banner-buttons span {                     /* For example, the name of the logged in user */
104         color: White;
105 }
106
107 .ctdl-logo-img {
108         background-color: White;
109         border-radius: 5px;
110         padding-bottom: 3px;
111         padding-left: 3px;
112         padding-right: 3px;
113 }
114
115 html,body,h1,h2,h3,h4,h5 {
116         font-family: sans-serif
117 }
118
119 .ctdl-modal {
120         display: none;                          /* set to "block" to make the modal appear */
121         z-index: 9;
122         position: fixed;
123         top: 50%;
124         left: 50%;
125         transform: translate(-50%, -50%);
126         border-style: outset;
127         border-width: 3px;
128         border-color: Black;
129         justify-content: center;
130         align-items: center;
131         padding: 10px;
132         background-color: GhostWhite;
133 }
134
135 .ctdl-modal-header {
136         background-color: GhostWhite;
137         padding: 10px;
138 }
139
140 .ctdl-modal-main {
141         padding: 10px;
142 }
143
144 .ctdl-modal-footer {
145         background-color: GhostWhite;
146         padding: 10px;
147 }
148
149 .ctdl-sidebar-button {
150         width: 100%;
151         padding: 10px;
152         text-align: left;
153         border: 1px solid GhostWhite;
154         background-color: GhostWhite;
155         color: Black;
156         font-size: 1.5vh;
157         border-radius: 5px;
158 }
159
160 .ctdl-sidebar-button:hover {
161         border-color: Blue;
162 }
163
164 .ctdl-sidebar-button-selected {
165         font-weight: bold;
166         background-color: Gainsboro;
167 }
168
169 .ctdl-grid-banner-item button {
170         background-color: #888888;
171         color: #FFFFFF;
172 }
173
174 .ctdl-forum-reading-pane {
175         background-color: White;        /* Background behind the message boxes */
176 }
177
178 .ctdl-fmsg-wrapper {                            /* message wrapper for forum view */
179         overflow: hidden;
180         border-radius: 10px;
181         background-color: White;
182         margin: 1vw;
183         padding: 5px;                           /* inside the box */
184         border-radius: 10px;
185         border-style: outset;
186         border-width: thin;
187 }
188
189 .ctdl-mmsg-wrapper {                            /* message wrapper for mailbox view */
190         overflow: hidden;
191         background-color: White;
192         padding: 5px;                           /* inside the box */
193 }
194
195 .ctdl-msg-reply {
196         margin-left: 5vw;
197 }
198
199 .ctdl-msg-header {
200         overflow: hidden;
201         padding: 4px;
202         min-height: 35px;
203         background-color: GhostWhite;
204         margin-bottom: 10px;                    /* this is the vertical space between the header and the message text */
205 }
206
207 .ctdl-msg-header-info {
208         float: left;
209 }
210
211 .ctdl-msg-header-buttons {
212         float: right;
213 }
214
215 .ctdl-msg-button {
216         margin-left: 2px;
217         border-radius: 5px;
218         background-color: Blue;
219         color: Black;
220         padding: 2px;
221         background-color: GhostWhite;
222         border-style: solid;
223         border-width: thin;
224         border-color: Black;
225         cursor: default;
226 }
227
228 .ctdl-msg-button:hover {
229         background-color: #123456;
230         color: GhostWhite;
231         transition: .3s;
232         border-color: #123456;
233         cursor: default;
234 }
235
236 .ctdl-msg-button a {
237         color: Black;
238         text-decoration: none;
239         cursor: default;
240 }
241
242 .ctdl-msg-button a:hover {
243         color: White;
244         cursor: default;
245 }
246
247 .ctdl-avatar {
248         width: 32px;
249 }
250
251 .ctdl-avatar img {
252         clip-path: circle(50%);
253 }
254
255 .ctdl-username {
256         font-weight: bold;
257         color: #000055;
258 }
259
260 .ctdl-username a {
261         text-decoration: none;
262         padding-right: 4px;
263 }
264
265 .ctdl-msgdate {
266         padding-left: 4px;
267 }
268
269 .ctdl-msgsubject {
270         font-weight: bold;
271 }
272
273 .ctdl-fmsg-content {                            /* message text, when in forum view */
274         margin-left: 32px;
275 }
276
277 .ctdl-mmsg-content {                            /* message text, when in mailbox view */
278         margin-left: 0;
279 }
280
281 .ctdl_mail_folders li {
282         color: DarkSlateGrey;
283 }
284
285 .ctdl_mail_folders li:hover {
286         color: Black;
287 }
288
289 .ctdl-avatar {
290         float: left;
291         padding-right: 2px;
292 }
293
294 .ctdl-forum-nav {
295         text-align: center;
296         color: Black;
297         background-color: Gainsboro;
298         padding-top: 5px;
299         padding-bottom: 5px;
300 }
301
302 .ctdl-forum-nav a {
303         text-decoration: none;
304 }
305
306 .ctdl-msg-body {
307 }
308
309 .ctdl-forum-editor-body {
310         padding-left: 5px;
311         padding-right: 5px;
312         padding-top: 1px black;
313         padding-bottom: 1px black;
314 }
315
316 blockquote {
317         background-color: #f5f5f5 !important;
318         color: Navy !important;
319         border-left: 2px solid Navy;
320         margin-bottom: 0px;
321         padding-bottom: 0px;
322         margin-left: 1em;
323         padding-left: 1em;
324 }
325
326 blockquote blockquote {
327         background-color: #ebebeb !important;
328         color: Maroon !important;
329         border-left: 2px solid Maroon;
330 }
331
332 blockquote blockquote blockquote {
333         background-color: #e1e1e1 !important;
334         color: Green !important;
335         border-left: 2px solid Green;
336 }
337
338 blockquote blockquote blockquote blockquote {
339         background-color: #d7d7d7 !important;
340         color: Purple !important;
341         border-left: 2px solid Purple;
342 }
343
344 blockquote blockquote blockquote blockquote blockquote {
345         background-color: #cdcdcd !important;
346         color: Teal !important;
347         border-left: 2px solid Teal;
348 }
349
350 blockquote pre {
351         margin-left: 1%;
352         margin-right: 1%;
353 }
354
355 .ctdl-forum-urlmodal {
356         width: 75%;
357 }
358
359 /* use this class for any small item that needs to be centered on the screen in the main div */
360 .ctdl-middle {
361         display: flex;
362         flex-direction: column;
363         justify-content: center;
364         align-items: center;
365         text-align: center;
366         min-height: 100vh;
367         background-color: GhostWhite;
368         overflow: none;
369         border: none;
370 }
371
372 .ctdl-roomlist-top {
373         background-color: GhostWhite;
374         width: 100%;
375         height: 100%;
376         overflow: auto;
377         border: none;
378 }
379
380 .ctdl-roomlist-floor {
381 }
382
383 .ctdl-roomlist-floor-label {
384         font-size: x-large;
385         margin: 1vw;
386         margin-bottom: 0;
387 }
388
389 .ctdl-roomlist-floor-rooms {
390 }
391
392 .ctdl-roomlist-room {
393         display: flex;
394         flex-direction: row;
395         flex-wrap: nowrap;
396         justify-content: space-around;
397         align-items: center;
398         overflow: hidden;
399         border-radius: 10px;
400         border-style: outset;
401         border-width: thin;
402         background-color: White;
403         padding: 0.3vw;
404         margin-top: 0;
405         margin-bottom: 0.1vw;
406         margin-left: 1vw;
407         margin-right: 1vw;
408 }
409
410 .ctdl-roomlist-roomicon {
411         overflow: hidden;
412         font-size: large;
413         margin-right: auto;
414 }
415
416 .ctdl-roomlist-roomname {
417         font-size: large;
418         margin-right: auto;
419         padding-left: 1vw;
420         padding-right: 1vw;
421 }
422
423 .ctdl-roomlist-roomname-hasnewmsgs {
424         font-weight: bold;
425         margin-right: auto;
426 }
427
428 .ctdl-roomlist-mtime {
429         margin-left: auto;
430 }
431
432 .ctdl-mailbox-grid-container {
433         display: grid;
434         position: relative;
435         overflow: hidden;
436         width: 100%;
437         height: 100%;
438         background-color: GhostWhite;
439         grid-template-rows: 15vw 1fr;           /* "1fr" means "all of the remaining space" */
440 }
441
442 .ctdl-mailbox-pane {                            /* list of messages when in mailbox view */
443         overflow-x: hidden;
444         overflow-y: scroll;
445         background-color: #DDDDDD;
446         border-bottom: solid 3px SlateGrey;     /* We can probably turn this into a drag handle */
447 }
448
449 .ctdl-mailbox-table {
450         width: 100%;
451         background-color: GhostWhite;
452         border-collapse: collapse;
453 }
454
455 .ctdl-mailbox-table td {
456         padding: 5px;
457 }
458
459 .ctdl-mailbox-table tr {
460         cursor: pointer;
461         border-top: solid 1px LightGrey;
462 }
463
464 .ctdl-mailbox-table tr:hover {
465         border-top: solid 1px Blue;
466         border-bottom: solid 1px Blue;
467         background-color: LightGrey;
468 }
469
470 .ctdl-mailbox-table th {
471         position: sticky;
472         top: 0;
473         z-index: 6;
474         background-color: SlateGrey;
475         color: White;
476         padding-top: 5px;
477         padding-bottom: 5px;
478 }
479
480 .ctdl-mailbox-table th:hover {                  /* Suppress highlighting the header bar */
481         background-color: SlateGrey;
482         color: White;
483         cursor: default;
484 }
485
486 .ctdl-mail-selected {
487         background-color: Blue;
488         color: White;
489 }
490
491 .ctdl-mail-subject {                            /* Subject column in mailbox message list */
492 }
493
494 .ctdl-mail-sender {                             /* Sender column in mailbox message list */
495 }
496
497 .ctdl-mail-date {                               /* Date column in mailbox message list */
498         white-space: nowrap;
499 }
500
501 .ctdl-mail-msgnum {                             /* # column in mailbox message list */
502         white-space: nowrap;
503 }
504
505 .ctdl-mailbox-reading-pane {                    /* message reading pane when in mailbox view */
506         overflow: auto;
507         background-color: GhostWhite;
508         padding: 5px;
509         overflow: auto;
510         border: none;
511 }
512
513 .ctdl-compose-mail {                            /* mail composition window */
514         width: 100%;
515         height: 100%;
516         overflow: none;
517         border: none;
518         padding: 0;
519         background-color: GhostWhite;
520         display: grid;
521         grid-template-rows: auto auto auto auto 1fr auto;
522         grid-template-columns: auto 1fr;
523         grid-template-areas:
524                 'ctdl-compose-to-label ctdl-compose-to-line'
525                 'ctdl-compose-cc-label ctdl-compose-cc-field'
526                 'ctdl-compose-bcc-label ctdl-compose-bcc-field'
527                 'ctdl-compose-subject-label ctdl-compose-subject-field'
528                 'ctdl-compose-message-box ctdl-compose-message-box'
529                 'ctdl-compose-toolbar ctdl-compose-toolbar';
530         gap: 3px;
531 }
532
533 .ctdl-compose-to-label {
534         grid-area: ctdl-compose-to-label;
535         padding: 0.5vw;
536 }
537
538 .ctdl-compose-to-line {
539         grid-area: ctdl-compose-to-line;
540         padding-left: 0;
541         padding-right: 0.5vw;
542         padding-top: 0.5vw;
543         padding-bottom: 1px;
544         border-bottom: 1px solid Grey;
545         margin-right: 0.5vw;
546         display: flex;
547         flex-direction: row;
548         flex-wrap: nowrap;
549         margin: 0;
550         width: 100%;
551         height: 100%;
552         overflow: hidden;
553 }
554
555 .ctdl-compose-to-field {
556         flex-grow: 1;
557
558 }
559
560 .ctdl-compose-cc-label {
561         grid-area: ctdl-compose-cc-label;
562         padding: 0.5vw;
563         display: none;
564 }
565
566 .ctdl-compose-cc-field {
567         grid-area: ctdl-compose-cc-field;
568         border-bottom: 1px solid Grey;
569         margin-right: 0.5vw;
570         display: none;
571         padding-left: 0;
572         padding-right: 0.5vw;
573         padding-top: 0.5vw;
574         padding-bottom: 0;
575 }
576
577 .ctdl-compose-bcc-label {
578         grid-area: ctdl-compose-bcc-label;
579         padding: 0.5vw;
580         display: none;
581 }
582
583 .ctdl-compose-bcc-field {
584         grid-area: ctdl-compose-bcc-field;
585         padding-left: 0;
586         padding-right: 0.5vw;
587         padding-top: 0.5vw;
588         padding-bottom: 0;
589         border-bottom: 1px solid Grey;
590         margin-right: 0.5vw;
591         display: none;
592 }
593
594 .ctdl-compose-subject-label {
595         grid-area: ctdl-compose-subject-label;
596         padding: 0.5vw;
597 }
598
599 .ctdl-compose-subject-field {
600         grid-area: ctdl-compose-subject-field;
601         padding-left: 0;
602         padding-right: 0.5vw;
603         padding-top: 0.5vw;
604         padding-bottom: 0;
605         border-bottom: 1px solid Grey;
606         margin-right: 0.5vw;
607 }
608
609 .ctdl-compose-message-box {
610         grid-area: ctdl-compose-message-box;
611         overflow-x: wrap;
612         overflow-y: auto;
613         padding: 0.5vw;
614         border-bottom: 1px solid Grey;
615         margin-left: 0.5vw;
616         margin-right: 0.5vw;
617 }
618
619 .ctdl-compose-toolbar {
620         grid-area: ctdl-compose-toolbar;
621         overflow: none;
622         padding: 0.5vw;
623         display: flex;
624         flex-direction: row;
625         flex-wrap: nowrap;
626         justify-content: space-between;
627         align-items: center;
628         margin: 0:
629         width: 100%;
630         height: 100%;
631         overflow: hidden;
632 }
633
634 .ctdl-login-screen-grid-container {
635         display: grid;
636         grid-template-columns: auto auto;
637 }
638
639 .ctdl-login-screen-grid-item {
640         padding: 20px;
641         font-size: 1.25em;
642         vertical-align: middle;
643 }
644
645 .ctdl-login-screen-grid-item input {
646         height: 100%;
647         border: none;
648         font-size: 1.25em;
649 }
650
651 .ctdl-fatal-error {
652         background-color: DarkRed;
653         margin-left: 1em;
654         margin-right: 1em;
655         padding: 1em;
656         font-size: 2em;
657         color: White;
658 }