2 // System wide notifications
9 background-color: #FFF;
10 @include lightDark(background-color, #fff, #444);
12 border-inline-start: 6px solid currentColor;
13 box-shadow: $bs-large;
17 transition: transform ease-in-out 280ms;
18 transform: translateX(580px);
20 grid-template-columns: 42px 1fr 12px;
24 vertical-align: middle;
31 padding-inline-end: $-s;
38 @include lightDark(color, #444, #888);
42 vertical-align: middle;
49 color: var(--color-positive);
52 color: var(--color-negative);
55 color: var(--color-warning);
58 transform: translateX(0);
61 transform: translate3d(0, -2px, 0);
65 .chapter-contents-toggle {
68 transition: all ease-in-out 180ms;
70 svg[data-icon="caret-right"] {
73 transition: all ease-in-out 180ms;
74 transform: rotate(0deg);
75 transform-origin: 50% 50%;
77 &.open svg[data-icon="caret-right"] {
78 transform: rotate(90deg);
80 svg[data-icon="caret-right"] + * {
81 margin-inline-start: $-xxs;
85 [overlay], .popup-background {
86 @include lightDark(background-color, rgba(0, 0, 0, 0.333), rgba(0, 0, 0, 0.6));
98 justify-content: center;
107 @include lightDark(background-color, #fff, #333);
114 box-shadow: 0 0 15px 0 rgba(0, 0, 0, 0.3);
118 flex-direction: column;
132 align-self: flex-start;
142 .popup-header button, .popup-footer button {
151 .popup-header button:not(.popup-header-close) {
155 .popup-header button:hover {
156 background-color: rgba(255, 255, 255, 0.1);
160 justify-content: end;
161 background-color: var(--color-primary-light);
168 .popup-header-close {
178 .popup-header, .popup-footer {
188 &.flex-container-row {
189 display: flex !important;
192 body.flexbox-support #entity-selector-wrap .popup-body .form-group {
196 #entity-selector-wrap .popup-body .form-group {
199 .popup-body .entity-selector-container {
206 justify-content: center;
214 border: 1px dashed var(--color-primary);
216 box-sizing: content-box;
217 background-clip: padding-box;
218 background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4' viewBox='0 0 4 4'%3E%3Cpath fill='%23a9a9a9' fill-opacity='0.52' d='M1 3h1v1H1V3zm2-2h1v1H3V1z'%3E%3C/path%3E%3C/svg%3E");
219 background-color: var(--color-primary);
223 pointer-events: none;
224 animation: dzAnimIn 240ms ease-in-out;
227 .dropzone-landing-area {
228 background-color: var(--color-primary-light);
231 border: 1px dashed var(--color-primary);
232 color: var(--color-primary);
236 @keyframes dzAnimIn {
239 transform: scale(.7);
242 transform: scale(1.1);
250 @keyframes dzFileItemIn {
253 transform: translateY(28px);
257 transform: translateY(0);
260 @keyframes dzFileItemOut {
263 transform: translateY(0);
267 transform: translateY(28px);
271 .dropzone-file-item {
278 @include lightDark(background, #FFF, #444);
279 box-shadow: $bs-large;
283 animation: dzFileItemIn ease-in-out 240ms;
284 transition: transform ease-in-out 120ms, box-shadow ease-in-out 120ms;
287 transform: translateY(-3px);
288 box-shadow: 0 3px 8px 1px rgba(22, 22, 22, 0.2);
291 .dropzone-file-item.dismiss {
292 animation: dzFileItemOut ease-in-out 240ms;
294 .dropzone-file-item .loading-container {
295 text-align: start !important;
298 .dropzone-file-item-image-wrap {
301 background-color: var(--color-primary-light);
309 .dropzone-file-item-text-wrap {
315 .dropzone-file-item-progress {
321 background-color: var(--color-primary);
322 transition: width ease-in-out 240ms;
324 .dropzone-file-item-label,
325 .dropzone-file-item-status {
330 .dropzone-file-item-status[data-status] {
336 .dropzone-file-item-status[data-status="success"] {
337 color: var(--color-positive);
339 .dropzone-file-item-status[data-status="error"] {
340 color: var(--color-negative);
342 .dropzone-file-item-status[data-status] + .dropzone-file-item-label {
346 .image-manager-body {
349 .image-manager-filter-bar {
353 @include lightDark(background-color, rgba(255, 255, 255, 0.85), rgba(80, 80, 80, 0.85));
355 .image-manager-filter-bar-bg {
365 .image-manager-filters {
369 border-bottom: 0 !important;
371 border: 1px solid #000 !important;
375 @include lightDark(background-color, #FFF, #333);
382 .image-manager-list {
385 grid-template-columns: repeat( auto-fill, minmax(max(140px, 17%), 1fr) );
393 .image-manager-list .image {
403 @include lightDark(border-color, #ddd, #000);
404 transition: all linear 80ms;
407 background-color: var(--color-primary-light);
408 outline: currentColor 3px solid;
410 transform: scale3d(0.95, 0.95, 0.95);
426 background-color: rgba(0, 0, 0, 0.7);
429 pointer-events: none;
430 transition: opacity ease-in-out 80ms;
435 &.selected .image-meta,
437 &:focus .image-meta {
440 @include smaller-than($m) {
447 .image-manager .load-more {
456 .image-manager .loading-container {
460 .image-manager-list .image-manager-list-warning {
465 .image-manager-warning {
466 @include lightDark(background, #FFF, #333);
467 color: var(--color-warning);
469 border-inline: 3px solid var(--color-warning);
472 .image-manager-sidebar {
477 border-inline-start: 1px solid #DDD;
478 @include lightDark(border-color, #ddd, #000);
483 .image-manager-viewer img {
487 margin: 0 auto $-m auto;
488 box-shadow: 0 1px 21px 1px rgba(76, 76, 76, 0.3);
490 .image-manager-viewer {
494 justify-content: center;
496 display: inline-block;
500 @include smaller-than($m) {
501 .image-manager-sidebar {
502 border-inline-start: 0;
506 .image-manager-content {
508 flex-direction: column;
519 .tab-container.bordered [role="tablist"] button[role="tab"] {
520 border-inline-end: 1px solid #DDD;
521 @include lightDark(border-inline-end-color, #DDD, #000);
523 border-inline-end: none;
527 .tab-container [role="tablist"] {
530 justify-items: start;
532 border-bottom: 1px solid #DDD;
533 @include lightDark(border-color, #ddd, #444);
537 .tab-container [role="tablist"] button[role="tab"] {
538 display: inline-block;
540 @include lightDark(color, rgba(0, 0, 0, .5), rgba(255, 255, 255, .5));
542 border-bottom: 2px solid transparent;
544 &[aria-selected="true"] {
545 color: var(--color-link) !important;
546 border-bottom-color: var(--color-link) !important;
547 outline: 0 !important;
550 @include lightDark(color, rgba(0, 0, 0, .8), rgba(255, 255, 255, .8));
551 @include lightDark(border-bottom-color, rgba(0, 0, 0, .2), rgba(255, 255, 255, .2));
554 outline: 1px dotted var(--color-primary);
555 outline-offset: -2px;
558 .tab-container [role="tablist"].controls-card {
564 .image-picker .none {
568 .code-editor .CodeMirror {
574 .code-editor .lang-options {
580 .code-editor .lang-options button {
583 border-bottom: 1px solid;
584 @include lightDark(color, #333, #AAA);
585 @include lightDark(border-bottom-color, #EEE, #000);
589 font-family: var(--font-code);
591 padding-left: 24px + $-xs;
593 background-color: var(--color-primary-light);
594 color: var(--color-primary);
598 .code-editor button.lang-option-favorite-toggle {
610 color: var(--color-primary);
616 .code-editor button[data-favourite="true"] ~ .action-favourite,
617 .code-editor button[data-favourite="false"] ~ .action-unfavourite {
621 .code-editor .action-favourite {
624 .code-editor button:hover ~ .action-favourite {
629 background-color: var(--color-primary-light);
631 color: var(--color-primary);
636 .code-editor-language-list {
640 align-items: stretch;
643 .code-editor-language-list input {
646 border-bottom: 1px solid #DDD;
662 .code-editor-body-wrap {
666 @include smaller-than($s) {
667 .code-editor .lang-options {
670 .code-editor-body-wrap {
671 flex-direction: column;
673 .code-editor-language-list, .code-editor-language-list input {
678 .comments-container {
679 padding-inline: $-xl;
680 @include smaller-than($m) {
681 padding-inline: $-xs;
686 border: 1px solid #DDD;
687 @include lightDark(border-color, #ddd, #000);
688 @include lightDark(background-color, #FFF, #222);
699 transition: opacity ease-in-out 120ms;
701 &:hover .actions, &:focus-within .actions {
704 .actions button:focus {
705 outline: 1px dotted var(--color-primary);
707 @include smaller-than($m) {
714 .comment-box .header {
715 border-bottom: 1px solid #DDD;
717 @include lightDark(border-color, #DDD, #000);
724 .meta a, .meta span {
727 .right-meta .text-muted {
732 .comment-thread-indicator {
733 border-inline-start: 3px dotted #DDD;
734 @include lightDark(border-color, #DDD, #444);
735 margin-inline-start: $-xs;
737 height: calc(100% - $-m);
740 .comment-branch .comment-branch .comment-branch .comment-branch .comment-thread-indicator {
746 margin: 0 !important;
747 margin-bottom: -$-xxs !important;
750 .comment-branch .comment-branch .comment-branch .comment-branch .comment-reply {
754 .comment-container-compact .comment-box {
768 .comment-container-compact .comment-thread-indicator {
772 #tag-manager .drag-card {
779 &:hover, .template-item-actions button:hover {
780 background-color: #F2F2F2;
782 .template-item-actions {
789 flex-direction: column;
790 border-inline-start: 1px solid;
791 @include lightDark(border-color, #ddd, #000);
793 .template-item-actions button {
796 @include lightDark(background-color, #FFF, #222);
798 border-top: 1px solid;
799 @include lightDark(border-color, #DDD, #000);
801 .template-item-actions button svg {
804 .template-item-actions button:first-child {
813 .dropdown-search-toggle-breadcrumb {
814 border: 1px solid transparent;
822 margin-inline-end: 0;
825 .dropdown-search-toggle-select {
841 text-overflow: ellipsis;
844 .dropdown-search-toggle-caret {
848 .dropdown-search-toggle-select-label {
852 .dropdown-search-toggle-select-caret {
860 .dropdown-search-dropdown {
875 .dropdown-search-search .svg-icon {
884 pointer-events: none;
886 .dropdown-search-list {
891 .dropdown-search-item {
894 background-color: #F2F2F2;
895 text-decoration: none;
899 padding-inline-start: $-xl;
902 border-bottom: 1px solid #DDD;
909 @include smaller-than($m) {
910 .dropdown-search-dropdown {
915 .dropdown-search-dropdown .dropdown-search-list {
921 box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1);
925 @include lightDark(border-color, #E2E2E2, #444);
926 border-bottom-width: 0;
931 @include lightDark(background-color, #F6F6F6, #333);
934 .item-list-row:first-child {
935 border-radius: 4px 4px 0 0;
937 .item-list-row:last-child {
938 border-radius: 0 0 4px 4px;
939 border-bottom-width: 1.5px;
941 .item-list-row:first-child:last-child {
944 .item-list-row-toggle-all {
947 .item-list-row:hover .item-list-row-toggle-all {
951 .status-indicator-active, .status-indicator-inactive {
955 display: inline-block;
957 .status-indicator-active {
958 background-color: var(--color-positive);
960 .status-indicator-inactive {
961 background-color: var(--color-negative);
964 .shortcut-container {
965 background-color: rgba(0, 0, 0, 0.25);
966 pointer-events: none;
976 box-shadow: 0 0 4px 0 #FFF;
981 padding: $-xxs $-xxs;
985 background-color: #eee;
987 border: 1px solid #b4b4b4;
988 box-shadow: 0 1px 1px rgba(0, 0, 0, .2), 0 2px 0 0 rgba(255, 255, 255, .7) inset;
995 background-color: var(--color-primary);
1004 width: math.div($btt-size, 1.5);
1005 height: math.div($btt-size, 1.5);
1006 margin-inline-end: 4px;
1010 border-radius: $btt-size;
1011 transition: all ease-in-out 180ms;
1016 width: $btt-size*3.4;
1017 opacity: 1 !important;
1020 width: $btt-size*3.4;
1024 vertical-align: top;
1029 // Sortable scroll boxes
1037 @include lightDark(border-color, #DDD, #000);
1040 @include lightDark(background-color, #EEE, #000);
1043 border-bottom: 1px solid;
1044 border-top: 1px solid;
1045 @include lightDark(border-color, #DDD, #000);
1047 @include lightDark(background-color, #FFF, #222);
1049 align-items: flex-start;
1056 @include lightDark(background-color, #f8f8f8, #333);
1075 @include lightDark(color, #444, #FFF);
1081 text-decoration: none;
1085 input.scroll-box-search, .scroll-box-header-item {
1088 @include lightDark(border-color, #DDD, #000);
1089 @include lightDark(background-color, #FFF, #222);
1090 margin-bottom: -1px;
1091 border-radius: 3px 3px 0 0;
1099 .scroll-box-search + .scroll-box,
1100 .scroll-box-header-item + .scroll-box {
1101 border-radius: 0 0 3px 3px;
1104 .scroll-box[refs="shelf-sort@shelf-book-list"] [data-action="add"] {
1107 .scroll-box[refs="shelf-sort@all-book-list"] [data-action="remove"],
1108 .scroll-box[refs="shelf-sort@all-book-list"] [data-action="move_up"],
1109 .scroll-box[refs="shelf-sort@all-book-list"] [data-action="move_down"],