7 // System wide notifications
13 padding: vars.$m vars.$l;
14 background-color: #FFF;
15 @include mixins.lightDark(background-color, #fff, #444);
17 border-inline-start: 6px solid currentColor;
18 box-shadow: vars.$bs-large;
22 transition: transform ease-in-out 280ms;
23 transform: translateX(580px);
25 grid-template-columns: 42px 1fr 12px;
29 vertical-align: middle;
36 padding-inline-end: vars.$s;
43 @include mixins.lightDark(color, #444, #888);
47 vertical-align: middle;
49 @include mixins.whenDark {
54 color: var(--color-positive);
57 color: var(--color-negative);
60 color: var(--color-warning);
63 transform: translateX(0);
66 transform: translate3d(0, -2px, 0);
70 .chapter-contents-toggle {
73 transition: all ease-in-out 180ms;
75 svg[data-icon="caret-right"] {
78 transition: all ease-in-out 180ms;
79 transform: rotate(0deg);
80 transform-origin: 50% 50%;
82 &.open svg[data-icon="caret-right"] {
83 transform: rotate(90deg);
85 svg[data-icon="caret-right"] + * {
86 margin-inline-start: vars.$xxs;
90 [overlay], .popup-background {
91 @include mixins.lightDark(background-color, rgba(0, 0, 0, 0.333), rgba(0, 0, 0, 0.6));
103 justify-content: center;
112 @include mixins.lightDark(background-color, #fff, #333);
119 box-shadow: 0 0 15px 0 rgba(0, 0, 0, 0.3);
123 flex-direction: column;
137 align-self: flex-start;
147 .popup-header button, .popup-footer button {
152 padding: vars.$xs vars.$m;
156 .popup-header button:not(.popup-header-close) {
160 .popup-header button:hover {
161 background-color: rgba(255, 255, 255, 0.1);
165 justify-content: end;
166 background-color: var(--color-primary-light);
169 padding: 10px vars.$m;
173 .popup-header-close {
183 .popup-header, .popup-footer {
190 margin-inline-end: auto;
191 padding: 8px vars.$m;
193 &.flex-container-row {
194 display: flex !important;
197 body.flexbox-support #entity-selector-wrap .popup-body .form-group {
201 #entity-selector-wrap .popup-body .form-group {
204 .popup-body .entity-selector-container {
211 justify-content: center;
219 border: 1px dashed var(--color-primary);
221 box-sizing: content-box;
222 background-clip: padding-box;
223 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");
224 background-color: var(--color-primary);
228 pointer-events: none;
229 animation: dzAnimIn 240ms ease-in-out;
232 .dropzone-landing-area {
233 background-color: var(--color-primary-light);
234 padding: vars.$m vars.$l;
236 border: 1px dashed var(--color-primary);
237 color: var(--color-primary);
241 @keyframes dzAnimIn {
244 transform: scale(.7);
247 transform: scale(1.1);
255 @keyframes dzFileItemIn {
258 transform: translateY(28px);
262 transform: translateY(0);
265 @keyframes dzFileItemOut {
268 transform: translateY(0);
272 transform: translateY(28px);
276 .dropzone-file-item {
283 @include mixins.lightDark(background, #FFF, #444);
284 box-shadow: vars.$bs-large;
288 animation: dzFileItemIn ease-in-out 240ms;
289 transition: transform ease-in-out 120ms, box-shadow ease-in-out 120ms;
292 transform: translateY(-3px);
293 box-shadow: 0 3px 8px 1px rgba(22, 22, 22, 0.2);
296 .dropzone-file-item.dismiss {
297 animation: dzFileItemOut ease-in-out 240ms;
299 .dropzone-file-item .loading-container {
300 text-align: start !important;
303 .dropzone-file-item-image-wrap {
306 background-color: var(--color-primary-light);
314 .dropzone-file-item-text-wrap {
320 .dropzone-file-item-progress {
326 background-color: var(--color-primary);
327 transition: width ease-in-out 240ms;
329 .dropzone-file-item-label {
331 margin-bottom: .2rem;
333 .dropzone-file-item-label,
334 .dropzone-file-item-status {
339 .dropzone-file-item-status[data-status] {
345 .dropzone-file-item-status[data-status="success"] {
346 color: var(--color-positive);
348 .dropzone-file-item-status[data-status="error"] {
349 color: var(--color-negative);
351 .dropzone-file-item-status[data-status] + .dropzone-file-item-label {
355 .image-manager-body {
358 .image-manager-filter-bar {
362 @include mixins.lightDark(background-color, rgba(255, 255, 255, 0.85), rgba(80, 80, 80, 0.85));
364 .image-manager-filter-bar-bg {
374 .image-manager-filters {
375 box-shadow: vars.$bs-med;
378 border-bottom: 0 !important;
379 @include mixins.whenDark {
380 border: 1px solid #000 !important;
384 @include mixins.lightDark(background-color, #FFF, #333);
391 .image-manager-list {
394 grid-template-columns: repeat( auto-fill, minmax(max(140px, 17%), 1fr) );
402 .image-manager-list .image {
412 @include mixins.lightDark(border-color, #ddd, #000);
413 transition: all linear 80ms;
416 background-color: var(--color-primary-light);
417 outline: currentColor 3px solid;
419 transform: scale3d(0.95, 0.95, 0.95);
435 background-color: rgba(0, 0, 0, 0.7);
438 pointer-events: none;
439 transition: opacity ease-in-out 80ms;
444 &.selected .image-meta,
446 &:focus .image-meta {
449 @include mixins.smaller-than(vars.$bp-m) {
456 .image-manager .load-more {
458 padding: vars.$s vars.$m;
465 .image-manager .loading-container {
469 .image-manager-list .image-manager-list-warning {
474 .image-manager-warning {
475 @include mixins.lightDark(background, #FFF, #333);
476 color: var(--color-warning);
478 border-inline: 3px solid var(--color-warning);
481 .image-manager-sidebar {
486 border-inline-start: 1px solid #DDD;
487 @include mixins.lightDark(border-color, #ddd, #000);
492 .image-manager-viewer img {
496 margin: 0 auto vars.$m auto;
497 box-shadow: 0 1px 21px 1px rgba(76, 76, 76, 0.3);
499 .image-manager-viewer {
503 justify-content: center;
505 display: inline-block;
509 @include mixins.smaller-than(vars.$bp-m) {
510 .image-manager-sidebar {
511 border-inline-start: 0;
515 .image-manager-content {
517 flex-direction: column;
528 .tab-container.bordered [role="tablist"] button[role="tab"] {
529 border-inline-end: 1px solid #DDD;
530 @include mixins.lightDark(border-inline-end-color, #DDD, #000);
532 border-inline-end: none;
536 .tab-container [role="tablist"] {
539 justify-items: start;
541 border-bottom: 1px solid #DDD;
542 @include mixins.lightDark(border-color, #ddd, #444);
543 margin-bottom: vars.$m;
546 .tab-container [role="tablist"] button[role="tab"] {
547 display: inline-block;
549 @include mixins.lightDark(color, rgba(0, 0, 0, .5), rgba(255, 255, 255, .5));
551 border-bottom: 2px solid transparent;
553 &[aria-selected="true"] {
554 color: var(--color-link) !important;
555 border-bottom-color: var(--color-link) !important;
556 outline: 0 !important;
559 @include mixins.lightDark(color, rgba(0, 0, 0, .8), rgba(255, 255, 255, .8));
560 @include mixins.lightDark(border-bottom-color, rgba(0, 0, 0, .2), rgba(255, 255, 255, .2));
563 outline: 1px dotted var(--color-primary);
564 outline-offset: -2px;
567 .tab-container [role="tablist"].controls-card {
573 .image-picker .none {
577 .code-editor .CodeMirror {
583 .code-editor .lang-options {
589 .code-editor .lang-options button {
591 padding: vars.$xs vars.$m;
592 border-bottom: 1px solid;
593 @include mixins.lightDark(color, #333, #AAA);
594 @include mixins.lightDark(border-bottom-color, #EEE, #000);
598 font-family: var(--font-code);
600 padding-left: 24px + vars.$xs;
602 background-color: var(--color-primary-light);
603 color: var(--color-primary);
607 .code-editor button.lang-option-favorite-toggle {
619 color: var(--color-primary);
625 .code-editor button[data-favourite="true"] ~ .action-favourite,
626 .code-editor button[data-favourite="false"] ~ .action-unfavourite {
630 .code-editor .action-favourite {
633 .code-editor button:hover ~ .action-favourite {
638 background-color: var(--color-primary-light);
640 color: var(--color-primary);
641 padding: vars.$xxs vars.$s;
645 .code-editor-language-list {
649 align-items: stretch;
652 .code-editor-language-list input {
655 border-bottom: 1px solid #DDD;
656 padding: vars.$xs vars.$s;
671 .code-editor-body-wrap {
675 @include mixins.smaller-than(vars.$bp-s) {
676 .code-editor .lang-options {
679 .code-editor-body-wrap {
680 flex-direction: column;
682 .code-editor-language-list, .code-editor-language-list input {
687 .comments-container {
688 padding-inline: vars.$xl;
689 @include mixins.smaller-than(vars.$bp-m) {
690 padding-inline: vars.$xs;
695 border: 1px solid #DDD;
696 @include mixins.lightDark(border-color, #ddd, #000);
697 @include mixins.lightDark(background-color, #FFF, #222);
700 padding: vars.$xs vars.$s;
702 font-size: vars.$fs-m;
708 transition: opacity ease-in-out 120ms;
710 &:hover .actions, &:focus-within .actions {
713 .actions button:focus {
714 outline: 1px dotted var(--color-primary);
716 @include mixins.smaller-than(vars.$bp-m) {
723 .comment-box .header {
724 border-bottom: 1px solid #DDD;
725 padding: vars.$xs vars.$s;
726 @include mixins.lightDark(border-color, #DDD, #000);
733 .meta a, .meta span {
736 .right-meta .text-muted {
741 .comment-thread-indicator {
742 border-inline-start: 3px dotted #DDD;
743 @include mixins.lightDark(border-color, #DDD, #444);
744 margin-inline-start: vars.$xs;
746 height: calc(100% - vars.$m);
749 .comment-branch .comment-branch .comment-branch .comment-branch .comment-thread-indicator {
755 margin: 0 !important;
756 margin-bottom: -(vars.$xxs) !important;
759 .comment-branch .comment-branch .comment-branch .comment-branch .comment-reply {
763 .comment-container-compact .comment-box {
774 padding: vars.$xs vars.$s;
777 .comment-container-compact .comment-thread-indicator {
781 #tag-manager .drag-card {
788 &:hover, .template-item-actions button:hover {
789 background-color: #F2F2F2;
791 .template-item-actions {
798 flex-direction: column;
799 border-inline-start: 1px solid;
800 @include mixins.lightDark(border-color, #ddd, #000);
802 .template-item-actions button {
805 @include mixins.lightDark(background-color, #FFF, #222);
807 border-top: 1px solid;
808 @include mixins.lightDark(border-color, #DDD, #000);
810 .template-item-actions button svg {
813 .template-item-actions button:first-child {
822 .dropdown-search-toggle-breadcrumb {
823 border: 1px solid transparent;
831 margin-inline-end: 0;
834 .dropdown-search-toggle-select {
850 text-overflow: ellipsis;
853 .dropdown-search-toggle-caret {
857 .dropdown-search-toggle-select-label {
861 .dropdown-search-toggle-select-caret {
869 .dropdown-search-dropdown {
870 box-shadow: vars.$bs-med;
880 @include mixins.rtl {
884 .dropdown-search-search .svg-icon {
887 @include mixins.rtl {
893 pointer-events: none;
895 .dropdown-search-list {
900 .dropdown-search-item {
901 padding: vars.$s vars.$m;
903 background-color: #F2F2F2;
904 text-decoration: none;
908 padding-inline-start: vars.$xl;
911 border-bottom: 1px solid #DDD;
918 @include mixins.smaller-than(vars.$bp-l) {
919 .dropdown-search-dropdown {
920 inset-inline: vars.$m auto;
922 .dropdown-search-dropdown .dropdown-search-list {
928 box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1);
932 @include mixins.lightDark(border-color, #E2E2E2, #444);
933 border-bottom-width: 0;
938 @include mixins.lightDark(background-color, #F6F6F6, #333);
941 .item-list-row:first-child {
942 border-radius: 4px 4px 0 0;
944 .item-list-row:last-child {
945 border-radius: 0 0 4px 4px;
946 border-bottom-width: 1.5px;
948 .item-list-row:first-child:last-child {
951 .item-list-row-toggle-all {
954 .item-list-row:hover .item-list-row-toggle-all {
958 .status-indicator-active, .status-indicator-inactive {
962 display: inline-block;
964 .status-indicator-active {
965 background-color: var(--color-positive);
967 .status-indicator-inactive {
968 background-color: var(--color-negative);
971 .shortcut-container {
972 background-color: rgba(0, 0, 0, 0.25);
973 pointer-events: none;
983 box-shadow: 0 0 4px 0 #FFF;
988 padding: vars.$xxs vars.$xxs;
992 background-color: #eee;
994 border: 1px solid #b4b4b4;
995 box-shadow: 0 1px 1px rgba(0, 0, 0, .2), 0 2px 0 0 rgba(255, 255, 255, .7) inset;
1002 background-color: var(--color-primary);
1011 width: math.div($btt-size, 1.5);
1012 height: math.div($btt-size, 1.5);
1013 margin-inline-end: 4px;
1017 border-radius: $btt-size;
1018 transition: all ease-in-out 180ms;
1023 width: $btt-size*3.4;
1024 opacity: 1 !important;
1027 width: $btt-size*3.4;
1031 vertical-align: top;
1036 // Sortable scroll boxes
1044 @include mixins.lightDark(border-color, #DDD, #000);
1047 @include mixins.lightDark(background-color, #EEE, #000);
1050 border-bottom: 1px solid;
1051 border-top: 1px solid;
1052 @include mixins.lightDark(border-color, #DDD, #000);
1054 @include mixins.lightDark(background-color, #FFF, #222);
1056 align-items: flex-start;
1063 @include mixins.lightDark(background-color, #f8f8f8, #333);
1066 align-items: center;
1080 padding: vars.$xs vars.$m;
1086 @include mixins.lightDark(color, #444, #FFF);
1092 text-decoration: none;
1096 input.scroll-box-search, .scroll-box-header-item {
1099 @include mixins.lightDark(border-color, #DDD, #000);
1100 @include mixins.lightDark(background-color, #FFF, #222);
1101 margin-bottom: -1px;
1102 border-radius: 3px 3px 0 0;
1110 .scroll-box-search + .scroll-box,
1111 .scroll-box-header-item + .scroll-box {
1112 border-radius: 0 0 3px 3px;
1115 .scroll-box.configured-option-list [data-action="add"] {
1118 .scroll-box.available-option-list [data-action="remove"],
1119 .scroll-box.available-option-list [data-action="move_up"],
1120 .scroll-box.available-option-list [data-action="move_down"],
1125 .scroll-box > li.empty-state {
1128 .scroll-box > li.empty-state:last-child {