11154 lines
		
	
	
	
		
			192 KiB
		
	
	
	
		
			SCSS
		
	
	
	
	
	
			
		
		
	
	
			11154 lines
		
	
	
	
		
			192 KiB
		
	
	
	
		
			SCSS
		
	
	
	
	
	
| @use 'sass:color';
 | |
| @use 'variables' as *;
 | |
| @use 'functions' as *;
 | |
| @use 'mixins' as *;
 | |
| 
 | |
| .app-body {
 | |
|   -webkit-overflow-scrolling: touch;
 | |
|   -ms-overflow-style: -ms-autohiding-scrollbar;
 | |
| }
 | |
| 
 | |
| .animated-number {
 | |
|   display: inline-flex;
 | |
|   flex-direction: column;
 | |
|   align-items: stretch;
 | |
|   overflow: hidden;
 | |
|   position: relative;
 | |
| }
 | |
| 
 | |
| .inline-alert {
 | |
|   color: $valid-value-color;
 | |
|   font-weight: 400;
 | |
| 
 | |
|   .no-reduce-motion & {
 | |
|     transition: opacity 200ms ease;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .link-button {
 | |
|   display: block;
 | |
|   font-size: 15px;
 | |
|   line-height: 20px;
 | |
|   color: $highlight-text-color;
 | |
|   border: 0;
 | |
|   background: transparent;
 | |
|   padding: 0;
 | |
|   cursor: pointer;
 | |
|   text-decoration: none;
 | |
| 
 | |
|   &--destructive {
 | |
|     color: $error-value-color;
 | |
|   }
 | |
| 
 | |
|   &:hover,
 | |
|   &:active {
 | |
|     text-decoration: underline;
 | |
|   }
 | |
| 
 | |
|   &:disabled {
 | |
|     color: $ui-primary-color;
 | |
|     cursor: default;
 | |
|   }
 | |
| 
 | |
|   &:focus-visible {
 | |
|     outline: $ui-button-icon-focus-outline;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .help-button {
 | |
|   background: $ui-button-background-color;
 | |
|   border: 0;
 | |
|   color: $ui-button-color;
 | |
|   border-radius: 20px;
 | |
|   cursor: pointer;
 | |
|   width: 24px;
 | |
|   height: 24px;
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   justify-content: center;
 | |
| 
 | |
|   &:active,
 | |
|   &:focus,
 | |
|   &:hover {
 | |
|     background-color: $ui-button-focus-background-color;
 | |
|   }
 | |
| 
 | |
|   &:focus-visible {
 | |
|     outline: $ui-button-icon-focus-outline;
 | |
|   }
 | |
| 
 | |
|   .icon {
 | |
|     width: 14px;
 | |
|     height: 14px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .button {
 | |
|   background-color: $ui-button-background-color;
 | |
|   border: 10px none;
 | |
|   border-radius: 4px;
 | |
|   box-sizing: border-box;
 | |
|   color: $ui-button-color;
 | |
|   cursor: pointer;
 | |
|   display: inline-flex;
 | |
|   align-items: center;
 | |
|   justify-content: center;
 | |
|   gap: 6px;
 | |
|   font-family: inherit;
 | |
|   font-size: 15px;
 | |
|   font-weight: 500;
 | |
|   letter-spacing: 0;
 | |
|   line-height: 22px;
 | |
|   overflow: hidden;
 | |
|   padding: 7px 18px;
 | |
|   position: relative;
 | |
|   text-align: center;
 | |
|   text-decoration: none;
 | |
|   text-overflow: ellipsis;
 | |
|   white-space: nowrap;
 | |
|   width: auto;
 | |
| 
 | |
|   &:active,
 | |
|   &:focus,
 | |
|   &:hover {
 | |
|     background-color: $ui-button-focus-background-color;
 | |
|   }
 | |
| 
 | |
|   &:focus-visible {
 | |
|     outline: $ui-button-icon-focus-outline;
 | |
|   }
 | |
| 
 | |
|   &--compact {
 | |
|     font-size: 14px;
 | |
|     line-height: normal;
 | |
|     font-weight: 700;
 | |
|     padding: 5px 12px;
 | |
|     border-radius: 4px;
 | |
|   }
 | |
| 
 | |
|   &--dangerous {
 | |
|     background-color: var(--error-background-color);
 | |
|     color: var(--on-error-color);
 | |
| 
 | |
|     &:active,
 | |
|     &:focus,
 | |
|     &:hover {
 | |
|       background-color: var(--error-active-background-color);
 | |
|       transition: none;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &--destructive {
 | |
|     &:active,
 | |
|     &:focus,
 | |
|     &:hover {
 | |
|       background-color: $ui-button-destructive-focus-background-color;
 | |
|       transition: none;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &:disabled,
 | |
|   &.disabled {
 | |
|     background-color: $ui-button-disabled-color;
 | |
|     cursor: not-allowed;
 | |
|   }
 | |
| 
 | |
|   &.copyable {
 | |
|     transition: background 300ms linear;
 | |
|   }
 | |
| 
 | |
|   &.copied {
 | |
|     background: $valid-value-color;
 | |
|     transition: none;
 | |
|   }
 | |
| 
 | |
|   &.button-secondary {
 | |
|     color: $highlight-text-color;
 | |
|     background: transparent;
 | |
|     padding: 6px 17px;
 | |
|     border: 1px solid $highlight-text-color;
 | |
| 
 | |
|     &:active,
 | |
|     &:focus,
 | |
|     &:hover {
 | |
|       border-color: lighten($highlight-text-color, 4%);
 | |
|       color: lighten($highlight-text-color, 4%);
 | |
|       background-color: transparent;
 | |
|       text-decoration: none;
 | |
|     }
 | |
| 
 | |
|     &.button--destructive {
 | |
|       &:active,
 | |
|       &:focus,
 | |
|       &:hover {
 | |
|         border-color: $ui-button-destructive-focus-background-color;
 | |
|         color: $ui-button-destructive-focus-background-color;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &:disabled,
 | |
|     &.disabled {
 | |
|       opacity: 0.7;
 | |
|       border-color: $ui-button-disabled-color;
 | |
|       color: $ui-button-disabled-color;
 | |
| 
 | |
|       &:active,
 | |
|       &:focus,
 | |
|       &:hover {
 | |
|         border-color: $ui-button-disabled-color;
 | |
|         color: $ui-button-disabled-color;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.button-tertiary {
 | |
|     background: transparent;
 | |
|     padding: 6px 17px;
 | |
|     color: $ui-button-tertiary-color;
 | |
|     border: 1px solid $ui-button-tertiary-border-color;
 | |
| 
 | |
|     &:active,
 | |
|     &:focus,
 | |
|     &:hover {
 | |
|       background-color: $ui-button-tertiary-focus-background-color;
 | |
|       color: $ui-button-tertiary-focus-color;
 | |
|       border: 0;
 | |
|       padding: 7px 18px;
 | |
|     }
 | |
| 
 | |
|     &:disabled {
 | |
|       opacity: 0.5;
 | |
|     }
 | |
| 
 | |
|     &.button--confirmation {
 | |
|       color: $valid-value-color;
 | |
|       border-color: $valid-value-color;
 | |
| 
 | |
|       &:active,
 | |
|       &:focus,
 | |
|       &:hover {
 | |
|         background: $valid-value-color;
 | |
|         color: $primary-text-color;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &.button--destructive {
 | |
|       color: $error-value-color;
 | |
|       border-color: $error-value-color;
 | |
| 
 | |
|       &:active,
 | |
|       &:focus,
 | |
|       &:hover {
 | |
|         background: $error-value-color;
 | |
|         color: $primary-text-color;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.button--block {
 | |
|     width: 100%;
 | |
|   }
 | |
| 
 | |
|   .icon {
 | |
|     width: 18px;
 | |
|     height: 18px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .column__wrapper {
 | |
|   display: flex;
 | |
|   flex: 1 1 auto;
 | |
|   position: relative;
 | |
| }
 | |
| 
 | |
| .icon {
 | |
|   flex: 0 0 auto;
 | |
|   width: 24px;
 | |
|   height: 24px;
 | |
|   aspect-ratio: 1;
 | |
| 
 | |
|   path {
 | |
|     fill: currentColor;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .icon-button {
 | |
|   display: inline-flex;
 | |
|   color: $action-button-color;
 | |
|   border: 0;
 | |
|   padding: 0;
 | |
|   border-radius: 4px;
 | |
|   background: transparent;
 | |
|   cursor: pointer;
 | |
|   align-items: center;
 | |
|   justify-content: center;
 | |
|   text-decoration: none;
 | |
|   gap: 4px;
 | |
|   flex: 0 0 auto;
 | |
| 
 | |
|   a {
 | |
|     display: flex;
 | |
|     color: inherit;
 | |
|     text-decoration: none;
 | |
|   }
 | |
| 
 | |
|   &:hover,
 | |
|   &:active,
 | |
|   &:focus {
 | |
|     color: lighten($action-button-color, 7%);
 | |
|     background-color: rgba($action-button-color, 0.15);
 | |
|   }
 | |
| 
 | |
|   &:focus-visible {
 | |
|     outline: $ui-button-icon-focus-outline;
 | |
|   }
 | |
| 
 | |
|   &.disabled {
 | |
|     color: darken($action-button-color, 13%);
 | |
|     background-color: transparent;
 | |
|     cursor: default;
 | |
|   }
 | |
| 
 | |
|   &.inverted {
 | |
|     color: $lighter-text-color;
 | |
| 
 | |
|     &:hover,
 | |
|     &:active,
 | |
|     &:focus {
 | |
|       color: darken($lighter-text-color, 7%);
 | |
|       background-color: rgba($lighter-text-color, 0.15);
 | |
|     }
 | |
| 
 | |
|     &:focus-visible {
 | |
|       outline: $ui-button-icon-focus-outline;
 | |
|     }
 | |
| 
 | |
|     &.disabled {
 | |
|       color: lighten($lighter-text-color, 7%);
 | |
|       background-color: transparent;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.active {
 | |
|     color: $highlight-text-color;
 | |
| 
 | |
|     &:hover,
 | |
|     &:active,
 | |
|     &:focus {
 | |
|       color: $highlight-text-color;
 | |
|       background-color: transparent;
 | |
|     }
 | |
| 
 | |
|     &.disabled {
 | |
|       color: lighten($highlight-text-color, 13%);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.overlayed {
 | |
|     box-sizing: content-box;
 | |
|     background: rgba($black, 0.65);
 | |
|     backdrop-filter: blur(10px) saturate(180%) contrast(75%) brightness(70%);
 | |
|     color: rgba($white, 0.7);
 | |
|     border-radius: 4px;
 | |
|     padding: 2px;
 | |
| 
 | |
|     &:hover {
 | |
|       background: rgba($black, 0.9);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &--with-counter {
 | |
|     padding-inline-end: 4px;
 | |
|   }
 | |
| 
 | |
|   &__counter {
 | |
|     display: block;
 | |
|     width: auto;
 | |
|     font-size: 12px;
 | |
|     font-weight: 500;
 | |
|   }
 | |
| 
 | |
|   &.copyable {
 | |
|     transition: all 300ms linear;
 | |
|   }
 | |
| 
 | |
|   &.copied {
 | |
|     border-color: $valid-value-color;
 | |
|     color: $valid-value-color;
 | |
|     transition: none;
 | |
|     background-color: rgba($valid-value-color, 0.15);
 | |
|   }
 | |
| }
 | |
| 
 | |
| .text-icon-button {
 | |
|   color: $lighter-text-color;
 | |
|   border: 0;
 | |
|   border-radius: 4px;
 | |
|   background: transparent;
 | |
|   cursor: pointer;
 | |
|   font-weight: 600;
 | |
|   font-size: 11px;
 | |
|   padding: 0 3px;
 | |
|   line-height: 27px;
 | |
|   white-space: nowrap;
 | |
| 
 | |
|   &:hover,
 | |
|   &:active,
 | |
|   &:focus {
 | |
|     color: darken($lighter-text-color, 7%);
 | |
|     background-color: rgba($lighter-text-color, 0.15);
 | |
|   }
 | |
| 
 | |
|   &:focus-visible {
 | |
|     outline: $ui-button-icon-focus-outline;
 | |
|   }
 | |
| 
 | |
|   &.disabled {
 | |
|     color: lighten($lighter-text-color, 20%);
 | |
|     background-color: transparent;
 | |
|     cursor: default;
 | |
|   }
 | |
| 
 | |
|   &.active {
 | |
|     color: $highlight-text-color;
 | |
| 
 | |
|     &:hover,
 | |
|     &:active,
 | |
|     &:focus {
 | |
|       color: $highlight-text-color;
 | |
|       background-color: transparent;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| body > [data-popper-placement] {
 | |
|   z-index: 3;
 | |
| }
 | |
| 
 | |
| .invisible {
 | |
|   font-size: 0;
 | |
|   line-height: 0;
 | |
|   display: inline-block;
 | |
|   width: 0;
 | |
|   height: 0;
 | |
|   position: absolute;
 | |
| 
 | |
|   img,
 | |
|   svg {
 | |
|     margin: 0 !important;
 | |
|     border: 0 !important;
 | |
|     padding: 0 !important;
 | |
|     width: 0 !important;
 | |
|     height: 0 !important;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .ellipsis {
 | |
|   &::after {
 | |
|     content: '…';
 | |
|   }
 | |
| }
 | |
| 
 | |
| .autosuggest-textarea {
 | |
|   &__textarea {
 | |
|     background: transparent;
 | |
|     min-height: 100px;
 | |
|     padding-bottom: 0;
 | |
|     resize: none;
 | |
|     scrollbar-color: initial;
 | |
| 
 | |
|     &::-webkit-scrollbar {
 | |
|       all: unset;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__suggestions {
 | |
|     box-shadow: var(--dropdown-shadow);
 | |
|     background: var(--input-background-color);
 | |
|     border: 1px solid var(--background-border-color);
 | |
|     border-radius: 0 0 4px 4px;
 | |
|     color: var(--on-input-color);
 | |
|     font-size: 14px;
 | |
|     padding: 0;
 | |
| 
 | |
|     &__item {
 | |
|       box-sizing: border-box;
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       height: 48px;
 | |
|       cursor: pointer;
 | |
|       font-size: 14px;
 | |
|       line-height: 20px;
 | |
|       letter-spacing: 0.25px;
 | |
|       color: var(--on-input-color);
 | |
| 
 | |
|       &:last-child {
 | |
|         border-radius: 0 0 4px 4px;
 | |
|       }
 | |
| 
 | |
|       &:hover,
 | |
|       &:focus,
 | |
|       &:active {
 | |
|         background: var(--dropdown-border-color);
 | |
| 
 | |
|         .autosuggest-account .display-name__account {
 | |
|           color: inherit;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       &.selected {
 | |
|         background: $ui-highlight-color;
 | |
|         color: $ui-button-color;
 | |
| 
 | |
|         .autosuggest-account .display-name__account {
 | |
|           color: inherit;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .autosuggest-account,
 | |
| .autosuggest-emoji,
 | |
| .autosuggest-hashtag {
 | |
|   flex: 1 0 0;
 | |
|   display: flex;
 | |
|   flex-direction: row;
 | |
|   align-items: center;
 | |
|   justify-content: flex-start;
 | |
|   gap: 12px;
 | |
|   padding: 8px 12px;
 | |
|   overflow: hidden;
 | |
|   text-overflow: ellipsis;
 | |
| }
 | |
| 
 | |
| .autosuggest-account {
 | |
|   .display-name {
 | |
|     font-weight: 400;
 | |
|     display: flex;
 | |
|     flex-direction: column;
 | |
|     flex: 1 0 0;
 | |
|   }
 | |
| 
 | |
|   .display-name__account {
 | |
|     display: block;
 | |
|     line-height: 16px;
 | |
|     font-size: 12px;
 | |
|     color: $ui-primary-color;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .autosuggest-hashtag {
 | |
|   justify-content: space-between;
 | |
| 
 | |
|   &__name {
 | |
|     flex: 1 1 auto;
 | |
|     overflow: hidden;
 | |
|     text-overflow: ellipsis;
 | |
|     white-space: nowrap;
 | |
|   }
 | |
| 
 | |
|   &__uses {
 | |
|     flex: 0 0 auto;
 | |
|     text-align: end;
 | |
|     overflow: hidden;
 | |
|     text-overflow: ellipsis;
 | |
|     white-space: nowrap;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .autosuggest-emoji {
 | |
|   &__name {
 | |
|     flex: 1 0 0;
 | |
|     overflow: hidden;
 | |
|     text-overflow: ellipsis;
 | |
|     white-space: nowrap;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .autosuggest-account .account__avatar,
 | |
| .autosuggest-emoji img {
 | |
|   display: block;
 | |
|   width: 24px;
 | |
|   height: 24px;
 | |
|   flex: 0 0 auto;
 | |
| }
 | |
| 
 | |
| .compose-form {
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
|   gap: 32px;
 | |
| 
 | |
|   .layout-multiple-columns &,
 | |
|   .column & {
 | |
|     padding: 15px;
 | |
|   }
 | |
| 
 | |
|   &__highlightable {
 | |
|     display: flex;
 | |
|     flex-direction: column;
 | |
|     gap: 16px;
 | |
|     flex: 0 1 auto;
 | |
|     border-radius: 4px;
 | |
|     border: 1px solid var(--background-border-color);
 | |
|     transition: border-color 300ms linear;
 | |
|     min-height: 0;
 | |
|     position: relative;
 | |
|     background: var(--input-background-color);
 | |
|     overflow-y: auto;
 | |
| 
 | |
|     &.active {
 | |
|       transition: none;
 | |
|       border-color: $ui-highlight-color;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__warning {
 | |
|     color: $inverted-text-color;
 | |
|     background: $ui-primary-color;
 | |
|     box-shadow: 0 2px 6px rgba($base-shadow-color, 0.3);
 | |
|     padding: 8px 10px;
 | |
|     border-radius: 4px;
 | |
|     font-size: 13px;
 | |
|     font-weight: 400;
 | |
| 
 | |
|     strong {
 | |
|       color: $inverted-text-color;
 | |
|       font-weight: 500;
 | |
| 
 | |
|       @each $lang in $cjk-langs {
 | |
|         &:lang(#{$lang}) {
 | |
|           font-weight: 700;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     a {
 | |
|       color: $lighter-text-color;
 | |
|       font-weight: 500;
 | |
|       text-decoration: underline;
 | |
| 
 | |
|       &:hover,
 | |
|       &:active,
 | |
|       &:focus {
 | |
|         text-decoration: none;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .spoiler-input {
 | |
|     display: flex;
 | |
|     align-items: stretch;
 | |
| 
 | |
|     &__border {
 | |
|       background: url('@/images/warning-stripes.svg') repeat-y;
 | |
|       width: 5px;
 | |
|       flex: 0 0 auto;
 | |
| 
 | |
|       &:first-child {
 | |
|         border-start-start-radius: 4px;
 | |
|       }
 | |
| 
 | |
|       &:last-child {
 | |
|         border-start-end-radius: 4px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .autosuggest-input {
 | |
|       flex: 1 1 auto;
 | |
|       border-bottom: 1px solid var(--background-border-color);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .autosuggest-textarea__textarea,
 | |
|   .spoiler-input__input {
 | |
|     display: block;
 | |
|     box-sizing: border-box;
 | |
|     width: 100%;
 | |
|     margin: 0;
 | |
|     color: $secondary-text-color;
 | |
|     background: var(--input-background-color);
 | |
|     font-family: inherit;
 | |
|     font-size: 14px;
 | |
|     padding: 12px;
 | |
|     line-height: normal;
 | |
|     border: 0;
 | |
|     outline: 0;
 | |
| 
 | |
|     &:focus {
 | |
|       outline: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .spoiler-input__input {
 | |
|     padding: 12px 12px - 5px;
 | |
|     background: rgba($ui-highlight-color, 0.05);
 | |
|     color: $highlight-text-color;
 | |
|   }
 | |
| 
 | |
|   &__dropdowns {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     gap: 8px;
 | |
| 
 | |
|     & > div {
 | |
|       overflow: hidden;
 | |
|       display: flex;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__uploads {
 | |
|     padding: 0 12px;
 | |
|     aspect-ratio: 3/2;
 | |
|   }
 | |
| 
 | |
|   .media-gallery {
 | |
|     gap: 8px;
 | |
|   }
 | |
| 
 | |
|   &__upload {
 | |
|     position: relative;
 | |
|     cursor: grab;
 | |
| 
 | |
|     &.dragging {
 | |
|       opacity: 0;
 | |
|     }
 | |
| 
 | |
|     &.overlay {
 | |
|       height: 100%;
 | |
|       border-radius: 8px;
 | |
|       pointer-events: none;
 | |
|     }
 | |
| 
 | |
|     &__drag-handle {
 | |
|       position: absolute;
 | |
|       top: 50%;
 | |
|       inset-inline-start: 0;
 | |
|       transform: translateY(-50%);
 | |
|       color: $white;
 | |
|       background: transparent;
 | |
|       border: 0;
 | |
|       padding: 8px 3px;
 | |
|       cursor: grab;
 | |
|     }
 | |
| 
 | |
|     &__actions {
 | |
|       display: flex;
 | |
|       align-items: flex-start;
 | |
|       justify-content: space-between;
 | |
|       padding: 8px;
 | |
|     }
 | |
| 
 | |
|     &__preview {
 | |
|       position: absolute;
 | |
|       width: 100%;
 | |
|       height: 100%;
 | |
|       border-radius: 6px;
 | |
|       z-index: -1;
 | |
|       top: 0;
 | |
|       inset-inline-start: 0;
 | |
|     }
 | |
| 
 | |
|     &__thumbnail {
 | |
|       width: 100%;
 | |
|       height: 100%;
 | |
|       background-position: center;
 | |
|       background-size: cover;
 | |
|       background-repeat: no-repeat;
 | |
|       overflow: hidden;
 | |
|     }
 | |
| 
 | |
|     .icon-button {
 | |
|       flex: 0 0 auto;
 | |
|       color: $white;
 | |
|       background: rgba(0, 0, 0, 75%);
 | |
|       border-radius: 6px;
 | |
|       font-size: 12px;
 | |
|       line-height: 16px;
 | |
|       font-weight: 500;
 | |
|       padding: 4px 8px;
 | |
|       font-family: inherit;
 | |
| 
 | |
|       .icon {
 | |
|         width: 15px;
 | |
|         height: 15px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .icon-button.compose-form__upload__delete {
 | |
|       padding: 2px;
 | |
|       border-radius: 50%;
 | |
| 
 | |
|       .icon {
 | |
|         width: 20px;
 | |
|         height: 20px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &__warning {
 | |
|       position: absolute;
 | |
|       z-index: 2;
 | |
|       bottom: 0;
 | |
|       inset-inline-start: 0;
 | |
|       inset-inline-end: 0;
 | |
|       padding: 8px;
 | |
| 
 | |
|       .icon-button.active {
 | |
|         color: #ffbe2e;
 | |
|         background: rgba(0, 0, 0, 75%);
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__footer {
 | |
|     display: flex;
 | |
|     flex-direction: column;
 | |
|     gap: 12px;
 | |
|     padding: 12px;
 | |
|     padding-top: 0;
 | |
|   }
 | |
| 
 | |
|   &__submit {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     flex: 1 1 auto;
 | |
|     max-width: 100%;
 | |
|     overflow: hidden;
 | |
|   }
 | |
| 
 | |
|   &__buttons {
 | |
|     display: flex;
 | |
|     gap: 8px;
 | |
|     align-items: center;
 | |
|     flex: 1 1 auto;
 | |
| 
 | |
|     & > div {
 | |
|       display: flex;
 | |
|     }
 | |
| 
 | |
|     .icon-button {
 | |
|       padding: 2px;
 | |
|     }
 | |
| 
 | |
|     .icon-button .icon {
 | |
|       width: 20px;
 | |
|       height: 20px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__actions {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     flex: 0 0 auto;
 | |
|     gap: 12px;
 | |
|     flex-wrap: wrap;
 | |
| 
 | |
|     .icon-button {
 | |
|       box-sizing: content-box;
 | |
|       color: $highlight-text-color;
 | |
| 
 | |
|       &:hover,
 | |
|       &:focus,
 | |
|       &:active {
 | |
|         color: $highlight-text-color;
 | |
|       }
 | |
| 
 | |
|       &.disabled {
 | |
|         color: $highlight-text-color;
 | |
|         opacity: 0.5;
 | |
|       }
 | |
| 
 | |
|       &.active {
 | |
|         background: $ui-highlight-color;
 | |
|         color: $primary-text-color;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__poll {
 | |
|     display: flex;
 | |
|     flex-direction: column;
 | |
|     align-self: stretch;
 | |
|     gap: 8px;
 | |
| 
 | |
|     .poll__option {
 | |
|       padding: 0 12px;
 | |
|       gap: 8px;
 | |
| 
 | |
|       &.empty:not(:focus-within) {
 | |
|         opacity: 0.5;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .poll__input {
 | |
|       width: 17px;
 | |
|       height: 17px;
 | |
|       border-color: $darker-text-color;
 | |
|     }
 | |
| 
 | |
|     &__footer {
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       gap: 16px;
 | |
|       padding-inline-start: 37px;
 | |
|       padding-inline-end: 40px;
 | |
| 
 | |
|       &__sep {
 | |
|         width: 1px;
 | |
|         height: 22px;
 | |
|         background: lighten($ui-base-color, 8%);
 | |
|         flex: 0 0 auto;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &__select {
 | |
|       display: flex;
 | |
|       flex-direction: column;
 | |
|       gap: 2px;
 | |
|       flex: 1 1 auto;
 | |
|       min-width: 0;
 | |
| 
 | |
|       &__label {
 | |
|         flex: 0 0 auto;
 | |
|         font-size: 11px;
 | |
|         font-weight: 500;
 | |
|         line-height: 16px;
 | |
|         letter-spacing: 0.5px;
 | |
|         color: $darker-text-color;
 | |
|         white-space: nowrap;
 | |
|         text-overflow: ellipsis;
 | |
|         overflow: hidden;
 | |
|       }
 | |
| 
 | |
|       &__value {
 | |
|         flex: 0 0 auto;
 | |
|         appearance: none;
 | |
|         background: transparent;
 | |
|         border: none;
 | |
|         padding: 0;
 | |
|         font-size: 14px;
 | |
|         font-weight: 500;
 | |
|         line-height: 20px;
 | |
|         letter-spacing: 0.1px;
 | |
|         color: $highlight-text-color;
 | |
|         white-space: nowrap;
 | |
|         text-overflow: ellipsis;
 | |
|         overflow: hidden;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .dropdown-button {
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   gap: 4px;
 | |
|   background: transparent;
 | |
|   color: $highlight-text-color;
 | |
|   border-radius: 6px;
 | |
|   border: 1px solid $highlight-text-color;
 | |
|   padding: 4px 8px;
 | |
|   font-size: 13px;
 | |
|   line-height: normal;
 | |
|   font-weight: 400;
 | |
|   overflow: hidden;
 | |
|   text-overflow: ellipsis;
 | |
|   white-space: nowrap;
 | |
| 
 | |
|   &[disabled] {
 | |
|     cursor: default;
 | |
|     color: $highlight-text-color;
 | |
|     border-color: $highlight-text-color;
 | |
|     opacity: 0.5;
 | |
|   }
 | |
| 
 | |
|   .icon {
 | |
|     width: 15px;
 | |
|     height: 15px;
 | |
|     flex: 0 0 auto;
 | |
|   }
 | |
| 
 | |
|   &__label {
 | |
|     overflow: hidden;
 | |
|     text-overflow: ellipsis;
 | |
|     white-space: nowrap;
 | |
|     flex: 1 1 auto;
 | |
|   }
 | |
| 
 | |
|   &.active {
 | |
|     background: $ui-highlight-color;
 | |
|     border-color: $ui-highlight-color;
 | |
|     color: $primary-text-color;
 | |
|   }
 | |
| 
 | |
|   &.warning {
 | |
|     border-color: var(--goldenrod-2);
 | |
|     color: var(--goldenrod-2);
 | |
| 
 | |
|     &.active {
 | |
|       background-color: var(--goldenrod-2);
 | |
|       color: var(--indigo-1);
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .character-counter {
 | |
|   cursor: default;
 | |
|   font-family: $font-sans-serif, sans-serif;
 | |
|   font-size: 14px;
 | |
|   font-weight: 400;
 | |
|   line-height: normal;
 | |
|   color: $darker-text-color;
 | |
|   flex: 1 0 auto;
 | |
|   text-align: end;
 | |
| 
 | |
|   &.character-counter--over {
 | |
|     color: $error-red;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .no-reduce-motion .spoiler-input {
 | |
|   transition:
 | |
|     height 0.4s ease,
 | |
|     opacity 0.4s ease;
 | |
| }
 | |
| 
 | |
| .sign-in-banner {
 | |
|   padding: 10px;
 | |
| 
 | |
|   p {
 | |
|     font-size: 15px;
 | |
|     line-height: 22px;
 | |
|     color: $secondary-text-color;
 | |
|     margin-bottom: 20px;
 | |
| 
 | |
|     strong {
 | |
|       font-weight: 700;
 | |
|     }
 | |
| 
 | |
|     a {
 | |
|       color: $secondary-text-color;
 | |
|       text-decoration: none;
 | |
|       unicode-bidi: isolate;
 | |
| 
 | |
|       &:hover {
 | |
|         text-decoration: underline;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .button {
 | |
|     margin-bottom: 10px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .emojione {
 | |
|   font-size: inherit;
 | |
|   vertical-align: middle;
 | |
|   object-fit: contain;
 | |
|   margin: -0.2ex 0.15em 0.2ex;
 | |
|   width: 16px;
 | |
|   height: 16px;
 | |
| 
 | |
|   img {
 | |
|     width: auto;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status__content--with-action {
 | |
|   cursor: pointer;
 | |
| }
 | |
| 
 | |
| .status__content {
 | |
|   clear: both;
 | |
| }
 | |
| 
 | |
| .status__content,
 | |
| .edit-indicator__content,
 | |
| .reply-indicator__content {
 | |
|   position: relative;
 | |
|   word-wrap: break-word;
 | |
|   font-weight: 400;
 | |
|   overflow: hidden;
 | |
|   text-overflow: ellipsis;
 | |
|   font-size: 15px;
 | |
|   line-height: 22px;
 | |
|   padding-top: 2px;
 | |
|   color: $primary-text-color;
 | |
| 
 | |
|   &:focus {
 | |
|     outline: 0;
 | |
|   }
 | |
| 
 | |
|   &.status__content--with-spoiler {
 | |
|     white-space: normal;
 | |
| 
 | |
|     .status__content__text {
 | |
|       white-space: pre-wrap;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .emojione {
 | |
|     width: 20px;
 | |
|     height: 20px;
 | |
|     margin: -3px 0 0;
 | |
|   }
 | |
| 
 | |
|   p {
 | |
|     margin-bottom: 22px;
 | |
|     white-space: pre-wrap;
 | |
|     unicode-bidi: plaintext;
 | |
| 
 | |
|     &:last-child {
 | |
|       margin-bottom: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   a {
 | |
|     color: $secondary-text-color;
 | |
|     text-decoration: none;
 | |
|     unicode-bidi: isolate;
 | |
| 
 | |
|     &:hover {
 | |
|       text-decoration: underline;
 | |
|     }
 | |
| 
 | |
|     &.mention {
 | |
|       &:hover {
 | |
|         text-decoration: none;
 | |
| 
 | |
|         span {
 | |
|           text-decoration: underline;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   a.unhandled-link {
 | |
|     color: $highlight-text-color;
 | |
|   }
 | |
| 
 | |
|   .status__content__text {
 | |
|     display: none;
 | |
| 
 | |
|     &.status__content__text--visible {
 | |
|       display: block;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .reply-indicator {
 | |
|   display: grid;
 | |
|   grid-template-columns: 46px minmax(0, 1fr);
 | |
|   grid-template-rows: 46px max-content;
 | |
|   gap: 0 10px;
 | |
| 
 | |
|   .detailed-status__display-name {
 | |
|     margin-bottom: 4px;
 | |
|   }
 | |
| 
 | |
|   .detailed-status__display-avatar {
 | |
|     grid-column-start: 1;
 | |
|     grid-row-start: 1;
 | |
|     grid-row-end: span 1;
 | |
|   }
 | |
| 
 | |
|   &__main {
 | |
|     grid-column-start: 2;
 | |
|     grid-row-start: 1;
 | |
|     grid-row-end: span 2;
 | |
|   }
 | |
| 
 | |
|   .display-name {
 | |
|     font-size: 14px;
 | |
|     line-height: 16px;
 | |
| 
 | |
|     &__account {
 | |
|       display: none;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__line {
 | |
|     grid-column-start: 1;
 | |
|     grid-row-start: 2;
 | |
|     grid-row-end: span 1;
 | |
|     position: relative;
 | |
| 
 | |
|     &::before {
 | |
|       display: block;
 | |
|       content: '';
 | |
|       position: absolute;
 | |
|       inset-inline-start: 50%;
 | |
|       top: 4px;
 | |
|       transform: translateX(-50%);
 | |
|       background: lighten($ui-base-color, 8%);
 | |
|       width: 2px;
 | |
|       height: calc(100% + 32px - 8px); // Account for gap to next element
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__content {
 | |
|     font-size: 14px;
 | |
|     line-height: 20px;
 | |
|     letter-spacing: 0.25px;
 | |
|     display: -webkit-box;
 | |
|     -webkit-line-clamp: 4;
 | |
|     -webkit-box-orient: vertical;
 | |
|     padding: 0;
 | |
|     max-height: 4 * 20px;
 | |
|     overflow: hidden;
 | |
|     color: $darker-text-color;
 | |
|   }
 | |
| 
 | |
|   &__attachments {
 | |
|     margin-top: 4px;
 | |
|     color: $darker-text-color;
 | |
|     font-size: 12px;
 | |
|     line-height: 16px;
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     gap: 4px;
 | |
| 
 | |
|     .icon {
 | |
|       width: 18px;
 | |
|       height: 18px;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .edit-indicator {
 | |
|   border-radius: 4px 4px 0 0;
 | |
|   background: lighten($ui-base-color, 4%);
 | |
|   padding: 12px;
 | |
|   overflow-y: auto;
 | |
|   flex: 0 0 auto;
 | |
|   border-bottom: 0.5px solid lighten($ui-base-color, 8%);
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
|   gap: 4px;
 | |
| 
 | |
|   &__header {
 | |
|     display: flex;
 | |
|     justify-content: space-between;
 | |
|     align-items: center;
 | |
|     color: $darker-text-color;
 | |
|     font-size: 12px;
 | |
|     line-height: 16px;
 | |
|     overflow: hidden;
 | |
|     text-overflow: ellipsis;
 | |
|   }
 | |
| 
 | |
|   &__cancel {
 | |
|     display: flex;
 | |
| 
 | |
|     .icon {
 | |
|       width: 18px;
 | |
|       height: 18px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__display-name {
 | |
|     display: flex;
 | |
|     gap: 4px;
 | |
| 
 | |
|     a {
 | |
|       color: inherit;
 | |
|       text-decoration: none;
 | |
| 
 | |
|       &:hover,
 | |
|       &:focus,
 | |
|       &:active {
 | |
|         text-decoration: underline;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__content {
 | |
|     color: $secondary-text-color;
 | |
|     font-size: 14px;
 | |
|     line-height: 20px;
 | |
|     letter-spacing: 0.25px;
 | |
|     padding-top: 0 !important;
 | |
|     display: -webkit-box;
 | |
|     -webkit-line-clamp: 4;
 | |
|     -webkit-box-orient: vertical;
 | |
|     max-height: 4 * 20px;
 | |
|     overflow: hidden;
 | |
| 
 | |
|     a {
 | |
|       color: $highlight-text-color;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__attachments {
 | |
|     color: $darker-text-color;
 | |
|     font-size: 12px;
 | |
|     line-height: 16px;
 | |
|     opacity: 0.75;
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     gap: 4px;
 | |
| 
 | |
|     .icon {
 | |
|       width: 18px;
 | |
|       height: 18px;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .edit-indicator__content,
 | |
| .reply-indicator__content {
 | |
|   .emojione {
 | |
|     width: 18px;
 | |
|     height: 18px;
 | |
|     margin: -3px 0 0;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .announcements__item__content {
 | |
|   word-wrap: break-word;
 | |
|   overflow-y: auto;
 | |
| 
 | |
|   .emojione {
 | |
|     width: 20px;
 | |
|     height: 20px;
 | |
|     margin: -3px 0 0;
 | |
|   }
 | |
| 
 | |
|   p {
 | |
|     margin-bottom: 10px;
 | |
|     white-space: pre-wrap;
 | |
| 
 | |
|     &:last-child {
 | |
|       margin-bottom: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   a {
 | |
|     color: $secondary-text-color;
 | |
|     text-decoration: none;
 | |
| 
 | |
|     &:hover {
 | |
|       text-decoration: underline;
 | |
|     }
 | |
| 
 | |
|     &.mention {
 | |
|       &:hover {
 | |
|         text-decoration: none;
 | |
| 
 | |
|         span {
 | |
|           text-decoration: underline;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &.unhandled-link {
 | |
|       color: $highlight-text-color;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status__content.status__content--collapsed {
 | |
|   max-height: 22px * 15; // 15 lines is roughly above 500 characters
 | |
| }
 | |
| 
 | |
| .status__content__read-more-button,
 | |
| .status__content__translate-button {
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   font-size: 15px;
 | |
|   line-height: 22px;
 | |
|   color: $highlight-text-color;
 | |
|   border: 0;
 | |
|   background: transparent;
 | |
|   padding: 0;
 | |
|   padding-top: 16px;
 | |
|   text-decoration: none;
 | |
| 
 | |
|   &:hover,
 | |
|   &:active {
 | |
|     text-decoration: underline;
 | |
|   }
 | |
| 
 | |
|   .icon {
 | |
|     width: 15px;
 | |
|     height: 15px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .translate-button {
 | |
|   margin-top: 16px;
 | |
|   font-size: 15px;
 | |
|   line-height: 22px;
 | |
|   display: flex;
 | |
|   justify-content: space-between;
 | |
|   color: $dark-text-color;
 | |
| }
 | |
| 
 | |
| .status__wrapper--filtered {
 | |
|   color: $dark-text-color;
 | |
|   border: 0;
 | |
|   font-size: inherit;
 | |
|   text-align: center;
 | |
|   line-height: inherit;
 | |
|   margin: 0;
 | |
|   padding: 15px;
 | |
|   box-sizing: border-box;
 | |
|   width: 100%;
 | |
|   clear: both;
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
| 
 | |
|   &__button {
 | |
|     display: inline;
 | |
|     color: lighten($ui-highlight-color, 8%);
 | |
|     border: 0;
 | |
|     background: transparent;
 | |
|     padding: 0;
 | |
|     font-size: inherit;
 | |
|     line-height: inherit;
 | |
| 
 | |
|     &:hover,
 | |
|     &:active {
 | |
|       text-decoration: underline;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .focusable {
 | |
|   &:focus {
 | |
|     outline: 0;
 | |
|     background: rgba($ui-highlight-color, 0.05);
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status--has-quote .quote-inline {
 | |
|   display: none;
 | |
| }
 | |
| 
 | |
| .status {
 | |
|   padding: 16px;
 | |
|   min-height: 54px;
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
|   cursor: auto;
 | |
|   opacity: 1;
 | |
|   animation: fade 150ms linear;
 | |
| 
 | |
|   @keyframes fade {
 | |
|     0% {
 | |
|       opacity: 0;
 | |
|     }
 | |
| 
 | |
|     100% {
 | |
|       opacity: 1;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .content-warning {
 | |
|     margin-bottom: 10px;
 | |
| 
 | |
|     &:last-child {
 | |
|       margin-bottom: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .media-gallery,
 | |
|   .video-player,
 | |
|   .audio-player,
 | |
|   .attachment-list {
 | |
|     margin-top: 16px;
 | |
|   }
 | |
| 
 | |
|   &--is-quote {
 | |
|     border: none;
 | |
|   }
 | |
| 
 | |
|   &--in-thread {
 | |
|     --thread-margin: calc(46px + 8px);
 | |
| 
 | |
|     border-bottom: 0;
 | |
| 
 | |
|     .status__content,
 | |
|     .status__action-bar,
 | |
|     .media-gallery,
 | |
|     .video-player,
 | |
|     .audio-player,
 | |
|     .attachment-list,
 | |
|     .picture-in-picture-placeholder,
 | |
|     .more-from-author,
 | |
|     .status-card,
 | |
|     .hashtag-bar,
 | |
|     .content-warning,
 | |
|     .filter-warning {
 | |
|       margin-inline-start: var(--thread-margin);
 | |
|       width: calc(100% - var(--thread-margin));
 | |
|     }
 | |
| 
 | |
|     .more-from-author {
 | |
|       width: calc(100% - var(--thread-margin) + 2px);
 | |
|     }
 | |
| 
 | |
|     .status__content__read-more-button {
 | |
|       margin-inline-start: var(--thread-margin);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__action-bar__button-wrapper {
 | |
|     flex-basis: 0;
 | |
|     flex-grow: 1;
 | |
| 
 | |
|     &:last-child {
 | |
|       flex-grow: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &--first-in-thread {
 | |
|     border-top: 1px solid var(--background-border-color);
 | |
|   }
 | |
| 
 | |
|   &__line {
 | |
|     height: 16px - 4px;
 | |
|     border-inline-start: 2px solid lighten($ui-base-color, 8%);
 | |
|     width: 0;
 | |
|     position: absolute;
 | |
|     top: 0;
 | |
|     inset-inline-start: 16px + ((46px - 2px) * 0.5);
 | |
| 
 | |
|     &--full {
 | |
|       top: 0;
 | |
|       height: 100%;
 | |
| 
 | |
|       &::before {
 | |
|         content: '';
 | |
|         display: block;
 | |
|         position: absolute;
 | |
|         top: 16px - 4px;
 | |
|         height: 46px + 4px + 4px;
 | |
|         width: 2px;
 | |
|         background: $ui-base-color;
 | |
|         inset-inline-start: -2px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &--first {
 | |
|       top: 16px + 46px + 4px;
 | |
|       height: calc(100% - (16px + 46px + 4px));
 | |
| 
 | |
|       &::before {
 | |
|         display: none;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status__relative-time {
 | |
|   display: block;
 | |
|   font-size: 15px;
 | |
|   line-height: 22px;
 | |
|   height: 40px;
 | |
|   order: 2;
 | |
|   flex: 0 0 auto;
 | |
|   color: $dark-text-color;
 | |
| }
 | |
| 
 | |
| .notification__relative_time {
 | |
|   color: $dark-text-color;
 | |
|   float: right;
 | |
|   font-size: 14px;
 | |
|   padding-bottom: 1px;
 | |
| }
 | |
| 
 | |
| .status__visibility-icon {
 | |
|   padding: 0 4px;
 | |
| 
 | |
|   .icon {
 | |
|     width: 1em;
 | |
|     height: 1em;
 | |
|     margin-bottom: -2px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status__display-name {
 | |
|   color: $dark-text-color;
 | |
| }
 | |
| 
 | |
| .status__info .status__display-name {
 | |
|   max-width: 100%;
 | |
|   display: flex;
 | |
|   font-size: 15px;
 | |
|   line-height: 22px;
 | |
|   align-items: center;
 | |
|   gap: 10px;
 | |
|   overflow: hidden;
 | |
| 
 | |
|   .display-name {
 | |
|     bdi {
 | |
|       overflow: hidden;
 | |
|       text-overflow: ellipsis;
 | |
|     }
 | |
| 
 | |
|     &__account {
 | |
|       white-space: nowrap;
 | |
|       display: block;
 | |
|       overflow: hidden;
 | |
|       text-overflow: ellipsis;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status__info {
 | |
|   font-size: 15px;
 | |
|   padding-bottom: 10px;
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   justify-content: space-between;
 | |
|   gap: 10px;
 | |
|   cursor: pointer;
 | |
| }
 | |
| 
 | |
| .status-check-box__status {
 | |
|   display: block;
 | |
|   box-sizing: border-box;
 | |
|   width: 100%;
 | |
|   padding: 0 10px;
 | |
| 
 | |
|   .detailed-status__display-name {
 | |
|     color: $dark-text-color;
 | |
| 
 | |
|     span {
 | |
|       display: inline;
 | |
|     }
 | |
| 
 | |
|     &:hover strong {
 | |
|       text-decoration: none;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .media-gallery,
 | |
|   .audio-player,
 | |
|   .video-player {
 | |
|     margin-top: 15px;
 | |
|     max-width: 250px;
 | |
|   }
 | |
| 
 | |
|   .status__content {
 | |
|     padding: 0;
 | |
|     white-space: normal;
 | |
|   }
 | |
| 
 | |
|   .media-gallery__item-thumbnail {
 | |
|     cursor: default;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status__prepend {
 | |
|   padding: 16px;
 | |
|   padding-bottom: 0;
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   gap: 8px;
 | |
|   font-size: 15px;
 | |
|   line-height: 22px;
 | |
|   font-weight: 500;
 | |
|   color: $dark-text-color;
 | |
| 
 | |
|   &__icon {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     justify-content: center;
 | |
|     flex: 0 0 auto;
 | |
| 
 | |
|     .icon {
 | |
|       width: 16px;
 | |
|       height: 16px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   a {
 | |
|     color: inherit;
 | |
|     text-decoration: none;
 | |
|   }
 | |
| 
 | |
|   > span {
 | |
|     display: block;
 | |
|     overflow: hidden;
 | |
|     text-overflow: ellipsis;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status__wrapper-direct,
 | |
| .notification-ungrouped--direct,
 | |
| .notification-group--direct,
 | |
| .notification-group--annual-report {
 | |
|   background: rgba($ui-highlight-color, 0.05);
 | |
| 
 | |
|   &:focus {
 | |
|     background: rgba($ui-highlight-color, 0.1);
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status__wrapper-direct,
 | |
| .notification-ungrouped--direct {
 | |
|   .status__prepend,
 | |
|   .notification-ungrouped__header {
 | |
|     color: $highlight-text-color;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status__action-bar {
 | |
|   display: flex;
 | |
|   justify-content: space-between;
 | |
|   align-items: center;
 | |
|   gap: 18px;
 | |
|   margin-top: 16px;
 | |
| }
 | |
| 
 | |
| .detailed-status__action-bar-dropdown {
 | |
|   flex: 1 1 auto;
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   justify-content: center;
 | |
|   position: relative;
 | |
| }
 | |
| 
 | |
| .detailed-status {
 | |
|   padding: 16px;
 | |
|   border-top: 1px solid var(--background-border-color);
 | |
| 
 | |
|   .status__content {
 | |
|     font-size: 19px;
 | |
|     line-height: 24px;
 | |
| 
 | |
|     .emojione {
 | |
|       width: 24px;
 | |
|       height: 24px;
 | |
|       margin: -1px 0 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .media-gallery,
 | |
|   .video-player,
 | |
|   .audio-player {
 | |
|     margin-top: 16px;
 | |
|   }
 | |
| 
 | |
|   .status__prepend {
 | |
|     padding: 0;
 | |
|     margin-bottom: 16px;
 | |
|   }
 | |
| 
 | |
|   .content-warning {
 | |
|     margin-bottom: 16px;
 | |
| 
 | |
|     &:last-child {
 | |
|       margin-bottom: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .logo {
 | |
|     width: 40px;
 | |
|     height: 40px;
 | |
|     color: $dark-text-color;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .embed {
 | |
|   position: relative;
 | |
| 
 | |
|   &__overlay {
 | |
|     display: block;
 | |
|     position: absolute;
 | |
|     top: 0;
 | |
|     left: 0;
 | |
|     width: 100%;
 | |
|     height: 100%;
 | |
|   }
 | |
| 
 | |
|   .detailed-status {
 | |
|     border-top: 0;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .scrollable > div:first-child .detailed-status {
 | |
|   border-top: 0;
 | |
| }
 | |
| 
 | |
| .detailed-status__meta {
 | |
|   margin-top: 24px;
 | |
|   color: $dark-text-color;
 | |
|   font-size: 14px;
 | |
|   line-height: 18px;
 | |
| 
 | |
|   &__line {
 | |
|     border-bottom: 1px solid var(--background-border-color);
 | |
|     padding: 8px 0;
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     gap: 8px;
 | |
| 
 | |
|     &:first-child {
 | |
|       padding-top: 0;
 | |
|     }
 | |
| 
 | |
|     &:last-child {
 | |
|       padding-bottom: 0;
 | |
|       border-bottom: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .icon {
 | |
|     width: 18px;
 | |
|     height: 18px;
 | |
|   }
 | |
| 
 | |
|   .animated-number {
 | |
|     color: $secondary-text-color;
 | |
|     font-weight: 500;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .detailed-status__action-bar {
 | |
|   border-top: 1px solid var(--background-border-color);
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
|   display: flex;
 | |
|   flex-direction: row;
 | |
|   padding: 10px 0;
 | |
| }
 | |
| 
 | |
| .detailed-status__wrapper-direct {
 | |
|   .detailed-status,
 | |
|   .detailed-status__action-bar {
 | |
|     background: color.mix($ui-base-color, $ui-highlight-color, 95%);
 | |
|   }
 | |
| 
 | |
|   &:focus {
 | |
|     .detailed-status,
 | |
|     .detailed-status__action-bar {
 | |
|       background: color.mix(
 | |
|         lighten($ui-base-color, 4%),
 | |
|         $ui-highlight-color,
 | |
|         95%
 | |
|       );
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .detailed-status__action-bar {
 | |
|     border-top-color: color.mix(
 | |
|       lighten($ui-base-color, 8%),
 | |
|       $ui-highlight-color,
 | |
|       95%
 | |
|     );
 | |
|   }
 | |
| 
 | |
|   .status__prepend {
 | |
|     color: $highlight-text-color;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status__quote {
 | |
|   --quote-margin: 36px;
 | |
| 
 | |
|   position: relative;
 | |
|   margin-block-start: 16px;
 | |
|   margin-inline-start: calc(var(--quote-margin) + var(--thread-margin, 0px));
 | |
|   border-radius: 8px;
 | |
|   color: var(--nested-card-text);
 | |
|   background: var(--nested-card-background);
 | |
|   border: var(--nested-card-border);
 | |
| 
 | |
|   @container (width > 460px) {
 | |
|     --quote-margin: 56px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status__quote--error {
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   gap: 8px;
 | |
|   padding: 12px;
 | |
|   font-size: 15px;
 | |
| }
 | |
| 
 | |
| .status__quote-author-button {
 | |
|   position: relative;
 | |
|   overflow: hidden;
 | |
|   display: inline-flex;
 | |
|   width: auto;
 | |
|   margin-block-start: 10px;
 | |
|   padding: 5px 12px;
 | |
|   align-items: center;
 | |
|   gap: 6px;
 | |
|   font-family: inherit;
 | |
|   font-size: 14px;
 | |
|   font-weight: 700;
 | |
|   line-height: normal;
 | |
|   letter-spacing: 0;
 | |
|   text-decoration: none;
 | |
|   color: $highlight-text-color;
 | |
|   background: var(--nested-card-background);
 | |
|   border: var(--nested-card-border);
 | |
|   border-radius: 4px;
 | |
| 
 | |
|   &:active,
 | |
|   &:focus,
 | |
|   &:hover {
 | |
|     border-color: lighten($highlight-text-color, 4%);
 | |
|     color: lighten($highlight-text-color, 4%);
 | |
|   }
 | |
| 
 | |
|   &:focus-visible {
 | |
|     outline: $ui-button-icon-focus-outline;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status__quote-icon {
 | |
|   position: absolute;
 | |
|   inset-block-start: 18px;
 | |
|   inset-inline-start: -40px;
 | |
|   display: block;
 | |
|   width: 26px;
 | |
|   height: 26px;
 | |
|   padding: 5px;
 | |
|   color: #6a49ba;
 | |
|   z-index: 10;
 | |
| 
 | |
|   .status__quote--error & {
 | |
|     inset-block-start: 50%;
 | |
|     transform: translateY(-50%);
 | |
|   }
 | |
| 
 | |
|   @container (width > 460px) {
 | |
|     inset-inline-start: -50px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .detailed-status__link {
 | |
|   display: inline-flex;
 | |
|   align-items: center;
 | |
|   color: inherit;
 | |
|   text-decoration: none;
 | |
|   gap: 6px;
 | |
| }
 | |
| 
 | |
| .domain {
 | |
|   padding: 16px;
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   gap: 8px;
 | |
| 
 | |
|   &__domain-name {
 | |
|     flex: 1 1 auto;
 | |
|     color: $primary-text-color;
 | |
|     font-size: 15px;
 | |
|     line-height: 21px;
 | |
|     font-weight: 500;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .account {
 | |
|   padding: 16px;
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
| 
 | |
|   .account__display-name {
 | |
|     flex: 1 1 auto;
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     gap: 10px;
 | |
|     color: $darker-text-color;
 | |
|     overflow: hidden;
 | |
|     text-decoration: none;
 | |
|     font-size: 14px;
 | |
| 
 | |
|     .display-name {
 | |
|       margin-bottom: 4px;
 | |
|     }
 | |
| 
 | |
|     .display-name strong {
 | |
|       display: inline;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &--minimal {
 | |
|     .account__display-name {
 | |
|       .display-name {
 | |
|         margin-bottom: 0;
 | |
|       }
 | |
| 
 | |
|       .display-name strong {
 | |
|         display: block;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__domain-pill {
 | |
|     display: inline-flex;
 | |
|     background: rgba($highlight-text-color, 0.2);
 | |
|     border-radius: 4px;
 | |
|     border: 0;
 | |
|     color: $highlight-text-color;
 | |
|     font-weight: 500;
 | |
|     font-size: 12px;
 | |
|     line-height: 16px;
 | |
|     padding: 4px 8px;
 | |
| 
 | |
|     &.active {
 | |
|       color: $white;
 | |
|       background: $ui-highlight-color;
 | |
|     }
 | |
| 
 | |
|     &__popout {
 | |
|       background: var(--dropdown-background-color);
 | |
|       backdrop-filter: var(--background-filter);
 | |
|       border: 1px solid var(--dropdown-border-color);
 | |
|       box-shadow: var(--dropdown-shadow);
 | |
|       max-width: 320px;
 | |
|       padding: 16px;
 | |
|       border-radius: 8px;
 | |
|       display: flex;
 | |
|       flex-direction: column;
 | |
|       gap: 24px;
 | |
|       font-size: 14px;
 | |
|       line-height: 20px;
 | |
|       color: $darker-text-color;
 | |
| 
 | |
|       .link-button {
 | |
|         display: inline;
 | |
|         font-size: inherit;
 | |
|         line-height: inherit;
 | |
|       }
 | |
| 
 | |
|       &__header {
 | |
|         display: flex;
 | |
|         align-items: center;
 | |
|         gap: 12px;
 | |
| 
 | |
|         &__icon {
 | |
|           width: 40px;
 | |
|           height: 40px;
 | |
|           background: $ui-highlight-color;
 | |
|           color: $white;
 | |
|           display: flex;
 | |
|           align-items: center;
 | |
|           justify-content: center;
 | |
|           border-radius: 50%;
 | |
|           flex-shrink: 0;
 | |
|         }
 | |
| 
 | |
|         h3 {
 | |
|           font-size: 17px;
 | |
|           line-height: 22px;
 | |
|           color: $primary-text-color;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       &__handle {
 | |
|         border: 2px dashed $highlight-text-color;
 | |
|         background: rgba($highlight-text-color, 0.1);
 | |
|         padding: 12px 8px;
 | |
|         color: $highlight-text-color;
 | |
|         border-radius: 4px;
 | |
| 
 | |
|         &__label {
 | |
|           font-size: 11px;
 | |
|           line-height: 16px;
 | |
|           font-weight: 500;
 | |
|         }
 | |
| 
 | |
|         &__handle {
 | |
|           overflow: hidden;
 | |
|           text-overflow: ellipsis;
 | |
|           user-select: all;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       &__parts {
 | |
|         display: flex;
 | |
|         flex-direction: column;
 | |
|         gap: 8px;
 | |
|         font-size: 12px;
 | |
|         line-height: 16px;
 | |
| 
 | |
|         & > div {
 | |
|           display: flex;
 | |
|           align-items: flex-start;
 | |
|           gap: 12px;
 | |
|         }
 | |
| 
 | |
|         &__icon {
 | |
|           width: 40px;
 | |
|           height: 40px;
 | |
|           display: flex;
 | |
|           align-items: center;
 | |
|           justify-content: center;
 | |
|           flex-shrink: 0;
 | |
|           color: $highlight-text-color;
 | |
|         }
 | |
| 
 | |
|         h6 {
 | |
|           font-size: 14px;
 | |
|           line-height: 20px;
 | |
|           font-weight: 500;
 | |
|           color: $primary-text-color;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__note {
 | |
|     font-size: 14px;
 | |
|     font-weight: 400;
 | |
|     overflow: hidden;
 | |
|     text-overflow: ellipsis;
 | |
|     display: -webkit-box;
 | |
|     -webkit-line-clamp: 1;
 | |
|     -webkit-box-orient: vertical;
 | |
|     margin-top: 10px;
 | |
|     color: $darker-text-color;
 | |
| 
 | |
|     &--missing {
 | |
|       color: $dark-text-color;
 | |
|     }
 | |
| 
 | |
|     p {
 | |
|       margin-bottom: 10px;
 | |
| 
 | |
|       &:last-child {
 | |
|         margin-bottom: 0;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     a {
 | |
|       color: inherit;
 | |
| 
 | |
|       &:hover,
 | |
|       &:focus,
 | |
|       &:active {
 | |
|         text-decoration: none;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .account__wrapper {
 | |
|   display: flex;
 | |
|   gap: 10px;
 | |
|   align-items: center;
 | |
|   justify-content: end;
 | |
| }
 | |
| 
 | |
| .account__wrapper--with-bio {
 | |
|   align-items: start;
 | |
| }
 | |
| 
 | |
| .account__info-wrapper {
 | |
|   flex: 1 1 auto;
 | |
|   min-width: 0;
 | |
| }
 | |
| 
 | |
| .account__avatar {
 | |
|   display: block;
 | |
|   position: relative;
 | |
|   border-radius: var(--avatar-border-radius);
 | |
|   background: var(--surface-background-color);
 | |
| 
 | |
|   @container (width < 360px) {
 | |
|     width: 35px !important;
 | |
|     height: 35px !important;
 | |
|   }
 | |
| 
 | |
|   img {
 | |
|     width: 100%;
 | |
|     height: 100%;
 | |
|     object-fit: cover;
 | |
|     border-radius: var(--avatar-border-radius);
 | |
|     display: inline-block; // to not show broken images
 | |
|   }
 | |
| 
 | |
|   &--loading {
 | |
|     background-color: var(--surface-background-color);
 | |
|   }
 | |
| 
 | |
|   &--inline {
 | |
|     display: inline-block;
 | |
|     vertical-align: middle;
 | |
|     margin-inline-end: 5px;
 | |
|   }
 | |
| 
 | |
|   &-composite {
 | |
|     border-radius: 50%;
 | |
|     overflow: hidden;
 | |
|     position: relative;
 | |
| 
 | |
|     & > div {
 | |
|       float: left;
 | |
|       position: relative;
 | |
|       box-sizing: border-box;
 | |
|     }
 | |
| 
 | |
|     .account__avatar {
 | |
|       width: 100% !important;
 | |
|       height: 100% !important;
 | |
|     }
 | |
| 
 | |
|     &__label {
 | |
|       display: block;
 | |
|       position: absolute;
 | |
|       top: 50%;
 | |
|       inset-inline-start: 50%;
 | |
|       transform: translate(-50%, -50%);
 | |
|       color: $primary-text-color;
 | |
|       text-shadow: 1px 1px 2px $base-shadow-color;
 | |
|       font-weight: 700;
 | |
|       font-size: 15px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__counter {
 | |
|     $height: 16px;
 | |
|     $h-padding: 5px;
 | |
| 
 | |
|     position: absolute;
 | |
|     bottom: -3px;
 | |
|     inset-inline-end: -3px;
 | |
|     padding-left: $h-padding;
 | |
|     padding-right: $h-padding;
 | |
|     height: $height;
 | |
|     border-radius: $height;
 | |
|     min-width: $height - 2 * $h-padding; // to ensure that it is never narrower than a circle
 | |
|     line-height: $height + 1px; // to visually center the numbers
 | |
|     background-color: $ui-button-background-color;
 | |
|     color: $white;
 | |
|     border-width: 1px;
 | |
|     border-style: solid;
 | |
|     border-color: var(--background-color);
 | |
|     font-size: 11px;
 | |
|     font-weight: 500;
 | |
|     text-align: center;
 | |
|   }
 | |
| }
 | |
| 
 | |
| a .account__avatar {
 | |
|   cursor: pointer;
 | |
| }
 | |
| 
 | |
| .avatar-group {
 | |
|   display: flex;
 | |
| 
 | |
|   --avatar-height: 28px;
 | |
| 
 | |
|   &:not(.avatar-group--compact) {
 | |
|     gap: 8px;
 | |
|     flex-wrap: wrap;
 | |
|     height: var(--avatar-height);
 | |
|     overflow-y: clip;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .avatar-group--compact {
 | |
|   & > :not(:first-child) {
 | |
|     margin-inline-start: -12px;
 | |
|   }
 | |
| 
 | |
|   & > :first-child {
 | |
|     transform: rotate(-4deg);
 | |
|   }
 | |
| 
 | |
|   & > :nth-child(2) {
 | |
|     transform: rotate(-2deg);
 | |
|   }
 | |
| 
 | |
|   .account__avatar {
 | |
|     box-shadow: 0 0 0 2px var(--background-color);
 | |
|   }
 | |
| }
 | |
| 
 | |
| .account__avatar-overlay {
 | |
|   position: relative;
 | |
| 
 | |
|   &-overlay {
 | |
|     position: absolute;
 | |
|     bottom: 0;
 | |
|     inset-inline-end: 0;
 | |
|     z-index: 1;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .account__relationship {
 | |
|   white-space: nowrap;
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   gap: 8px;
 | |
| }
 | |
| 
 | |
| .account__relationship,
 | |
| .explore-suggestions-card {
 | |
|   .icon-button {
 | |
|     border: 1px solid var(--background-border-color);
 | |
|     border-radius: 4px;
 | |
|     box-sizing: content-box;
 | |
|     padding: 5px;
 | |
| 
 | |
|     .icon {
 | |
|       width: 24px;
 | |
|       height: 24px;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .account-authorize {
 | |
|   padding: 14px 10px;
 | |
| 
 | |
|   .detailed-status__display-name {
 | |
|     display: block;
 | |
|     margin-bottom: 15px;
 | |
|     overflow: hidden;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .account-authorize__avatar {
 | |
|   float: left;
 | |
|   margin-inline-end: 10px;
 | |
| }
 | |
| 
 | |
| .status__display-name,
 | |
| .status__relative-time,
 | |
| .detailed-status__display-name,
 | |
| .detailed-status__datetime,
 | |
| .detailed-status__application,
 | |
| .account__display-name {
 | |
|   text-decoration: none;
 | |
| }
 | |
| 
 | |
| .status__display-name,
 | |
| .account__display-name {
 | |
|   .display-name strong {
 | |
|     color: $primary-text-color;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .muted {
 | |
|   .emojione {
 | |
|     opacity: 0.5;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status__display-name,
 | |
| .detailed-status__display-name,
 | |
| a.account__display-name {
 | |
|   &:hover .display-name strong {
 | |
|     text-decoration: underline;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .account__display-name .display-name strong {
 | |
|   display: block;
 | |
|   overflow: hidden;
 | |
|   text-overflow: ellipsis;
 | |
| }
 | |
| 
 | |
| .detailed-status__application,
 | |
| .detailed-status__datetime {
 | |
|   color: inherit;
 | |
| }
 | |
| 
 | |
| .detailed-status__display-name {
 | |
|   color: $darker-text-color;
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   gap: 10px;
 | |
|   font-size: 15px;
 | |
|   line-height: 22px;
 | |
|   margin-bottom: 16px;
 | |
|   overflow: hidden;
 | |
| 
 | |
|   strong,
 | |
|   span {
 | |
|     display: block;
 | |
|     text-overflow: ellipsis;
 | |
|     overflow: hidden;
 | |
|   }
 | |
| 
 | |
|   strong {
 | |
|     color: $primary-text-color;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .muted {
 | |
|   .status__content,
 | |
|   .status__content p,
 | |
|   .status__content a {
 | |
|     color: $dark-text-color;
 | |
|   }
 | |
| 
 | |
|   .status__display-name strong {
 | |
|     color: $dark-text-color;
 | |
|   }
 | |
| 
 | |
|   .status__avatar {
 | |
|     opacity: 0.5;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .notification__report {
 | |
|   padding: 16px;
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
|   display: flex;
 | |
|   gap: 10px;
 | |
| 
 | |
|   &__avatar {
 | |
|     flex: 0 0 auto;
 | |
|   }
 | |
| 
 | |
|   &__details {
 | |
|     flex: 1 1 auto;
 | |
|     display: flex;
 | |
|     justify-content: space-between;
 | |
|     align-items: center;
 | |
|     color: $darker-text-color;
 | |
|     gap: 10px;
 | |
|     font-size: 15px;
 | |
|     line-height: 22px;
 | |
|     white-space: nowrap;
 | |
|     overflow: hidden;
 | |
| 
 | |
|     & > div {
 | |
|       overflow: hidden;
 | |
|       text-overflow: ellipsis;
 | |
|     }
 | |
| 
 | |
|     strong {
 | |
|       font-weight: 500;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__actions {
 | |
|     flex: 0 0 auto;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .notification-group--link {
 | |
|   color: $secondary-text-color;
 | |
|   text-decoration: none;
 | |
| 
 | |
|   .notification-group__main {
 | |
|     display: flex;
 | |
|     flex-direction: column;
 | |
|     align-items: flex-start;
 | |
|     gap: 8px;
 | |
|     flex-grow: 1;
 | |
|     font-size: 15px;
 | |
|     line-height: 22px;
 | |
| 
 | |
|     strong,
 | |
|     bdi {
 | |
|       font-weight: 700;
 | |
|     }
 | |
| 
 | |
|     .link-button {
 | |
|       font-size: inherit;
 | |
|       line-height: inherit;
 | |
|       font-weight: inherit;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .notification__message {
 | |
|   padding: 16px;
 | |
|   padding-bottom: 0;
 | |
|   cursor: default;
 | |
|   color: $darker-text-color;
 | |
|   font-size: 15px;
 | |
|   line-height: 22px;
 | |
|   font-weight: 500;
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   gap: 10px;
 | |
| 
 | |
|   .icon {
 | |
|     color: $highlight-text-color;
 | |
|     width: 18px;
 | |
|     height: 18px;
 | |
|   }
 | |
| 
 | |
|   .icon-star {
 | |
|     color: $gold-star;
 | |
|   }
 | |
| 
 | |
|   > span {
 | |
|     display: inline;
 | |
|     overflow: hidden;
 | |
|     text-overflow: ellipsis;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .icon-button.star-icon.active {
 | |
|   color: $gold-star;
 | |
| }
 | |
| 
 | |
| .icon-button.bookmark-icon.active {
 | |
|   color: $red-bookmark;
 | |
| }
 | |
| 
 | |
| .no-reduce-motion .icon-button.star-icon {
 | |
|   &.activate {
 | |
|     & > .icon {
 | |
|       animation: spring-rotate-in 1s linear;
 | |
|       transform-origin: 50% 52%;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.deactivate {
 | |
|     & > .icon {
 | |
|       animation: spring-rotate-out 1s linear;
 | |
|       transform-origin: 50% 52%;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .notification__display-name {
 | |
|   color: inherit;
 | |
|   font-weight: 500;
 | |
|   text-decoration: none;
 | |
| 
 | |
|   &:hover {
 | |
|     text-decoration: underline;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .display-name {
 | |
|   display: block;
 | |
|   max-width: 100%;
 | |
|   overflow: hidden;
 | |
|   text-overflow: ellipsis;
 | |
|   white-space: nowrap;
 | |
| 
 | |
|   &__account {
 | |
|     text-overflow: ellipsis;
 | |
|     overflow: hidden;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .display-name__html {
 | |
|   font-weight: 500;
 | |
| }
 | |
| 
 | |
| .status__relative-time,
 | |
| .detailed-status__datetime {
 | |
|   &:hover {
 | |
|     text-decoration: underline;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .zoomable-image {
 | |
|   position: relative;
 | |
|   width: 100%;
 | |
|   height: 100%;
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   justify-content: center;
 | |
|   scrollbar-width: none;
 | |
|   overflow: hidden;
 | |
|   user-select: none;
 | |
| 
 | |
|   img {
 | |
|     max-width: $media-modal-media-max-width;
 | |
|     max-height: $media-modal-media-max-height;
 | |
|     width: auto;
 | |
|     height: auto;
 | |
|     outline: 1px solid var(--media-outline-color);
 | |
|     outline-offset: -1px;
 | |
|     border-radius: 8px;
 | |
|     touch-action: none;
 | |
|   }
 | |
| 
 | |
|   &--zoomed-in {
 | |
|     z-index: 9999;
 | |
|     cursor: grab;
 | |
| 
 | |
|     img {
 | |
|       outline: none;
 | |
|       border-radius: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &--dragging {
 | |
|     cursor: grabbing;
 | |
|   }
 | |
| 
 | |
|   &--error img {
 | |
|     visibility: hidden;
 | |
|   }
 | |
| 
 | |
|   &__preview {
 | |
|     max-width: $media-modal-media-max-width;
 | |
|     max-height: $media-modal-media-max-height;
 | |
|     position: absolute;
 | |
|     z-index: 1;
 | |
|     outline: 1px solid var(--media-outline-color);
 | |
|     outline-offset: -1px;
 | |
|     border-radius: 8px;
 | |
|     overflow: hidden;
 | |
| 
 | |
|     canvas {
 | |
|       position: absolute;
 | |
|       width: 100%;
 | |
|       height: 100%;
 | |
|       object-fit: cover;
 | |
|       z-index: -1;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .loading-indicator {
 | |
|     z-index: 2;
 | |
|     mix-blend-mode: luminosity;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .navigation-bar {
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   flex-shrink: 0;
 | |
|   cursor: default;
 | |
|   gap: 10px;
 | |
| 
 | |
|   .column > & {
 | |
|     padding: 15px;
 | |
|   }
 | |
| 
 | |
|   .account {
 | |
|     border-bottom: 0;
 | |
|     padding: 0;
 | |
|     flex: 1 1 auto;
 | |
|     min-width: 0;
 | |
| 
 | |
|     &__display-name {
 | |
|       font-size: 14px;
 | |
|       line-height: 20px;
 | |
|       font-weight: 500;
 | |
| 
 | |
|       .display-name__account {
 | |
|         font-size: 14px;
 | |
|         font-weight: 400;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .icon-button {
 | |
|     padding: 8px;
 | |
|     color: $secondary-text-color;
 | |
|   }
 | |
| 
 | |
|   .icon-button .icon {
 | |
|     width: 24px;
 | |
|     height: 24px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .dropdown-animation {
 | |
|   animation: dropdown 250ms cubic-bezier(0.1, 0.7, 0.1, 1);
 | |
| 
 | |
|   @keyframes dropdown {
 | |
|     from {
 | |
|       opacity: 0;
 | |
|     }
 | |
| 
 | |
|     to {
 | |
|       opacity: 1;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .reduce-motion & {
 | |
|     animation: none;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .dropdown {
 | |
|   display: inline-block;
 | |
| }
 | |
| 
 | |
| .dropdown__content {
 | |
|   display: none;
 | |
|   position: absolute;
 | |
| }
 | |
| 
 | |
| .dropdown-menu__separator {
 | |
|   border-bottom: 1px solid var(--dropdown-border-color);
 | |
|   margin: 5px 0;
 | |
|   height: 0;
 | |
| }
 | |
| 
 | |
| .dropdown-menu {
 | |
|   background: var(--dropdown-background-color);
 | |
|   backdrop-filter: var(--background-filter);
 | |
|   border: 1px solid var(--dropdown-border-color);
 | |
|   padding: 4px;
 | |
|   border-radius: 4px;
 | |
|   box-shadow: var(--dropdown-shadow);
 | |
|   z-index: 9999;
 | |
| 
 | |
|   &__text-button {
 | |
|     display: inline-flex;
 | |
|     align-items: center;
 | |
|     color: inherit;
 | |
|     background: transparent;
 | |
|     border: 0;
 | |
|     margin: 0;
 | |
|     padding: 0;
 | |
|     font-family: inherit;
 | |
|     font-size: inherit;
 | |
|     line-height: inherit;
 | |
| 
 | |
|     &:focus-visible {
 | |
|       outline: 1px dotted;
 | |
|     }
 | |
| 
 | |
|     &:hover {
 | |
|       text-decoration: underline;
 | |
|     }
 | |
| 
 | |
|     .icon {
 | |
|       width: 15px;
 | |
|       height: 15px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__container {
 | |
|     &__header {
 | |
|       border-bottom: 1px solid var(--dropdown-border-color);
 | |
|       padding: 10px 14px;
 | |
|       padding-bottom: 14px;
 | |
|       margin-bottom: 4px;
 | |
|       font-size: 13px;
 | |
|       line-height: 18px;
 | |
|       color: $darker-text-color;
 | |
|     }
 | |
| 
 | |
|     &__list {
 | |
|       list-style: none;
 | |
| 
 | |
|       &--scrollable {
 | |
|         max-height: 300px;
 | |
|         overflow-y: scroll;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &--loading {
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       justify-content: center;
 | |
|       padding: 30px 45px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.left {
 | |
|     transform-origin: 100% 50%;
 | |
|   }
 | |
| 
 | |
|   &.top {
 | |
|     transform-origin: 50% 100%;
 | |
|   }
 | |
| 
 | |
|   &.bottom {
 | |
|     transform-origin: 50% 0;
 | |
|   }
 | |
| 
 | |
|   &.right {
 | |
|     transform-origin: 0 50%;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .dropdown-menu__item {
 | |
|   font-size: 13px;
 | |
|   line-height: 18px;
 | |
|   font-weight: 500;
 | |
|   display: block;
 | |
| 
 | |
|   &--dangerous {
 | |
|     color: $error-value-color;
 | |
|   }
 | |
| 
 | |
|   a,
 | |
|   button {
 | |
|     font: inherit;
 | |
|     display: block;
 | |
|     width: 100%;
 | |
|     padding: 10px 14px;
 | |
|     border: 0;
 | |
|     margin: 0;
 | |
|     background: transparent;
 | |
|     box-sizing: border-box;
 | |
|     text-decoration: none;
 | |
|     color: inherit;
 | |
|     overflow: hidden;
 | |
|     text-overflow: ellipsis;
 | |
|     white-space: nowrap;
 | |
|     text-align: inherit;
 | |
|     border-radius: 4px;
 | |
| 
 | |
|     &:focus,
 | |
|     &:hover,
 | |
|     &:active {
 | |
|       background: var(--dropdown-border-color);
 | |
|       outline: 0;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .inline-account {
 | |
|   display: inline-flex;
 | |
|   align-items: center;
 | |
|   vertical-align: top;
 | |
| 
 | |
|   .account__avatar {
 | |
|     margin-inline-end: 5px;
 | |
|     border-radius: 50%;
 | |
|   }
 | |
| 
 | |
|   strong {
 | |
|     font-weight: 600;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .columns-area {
 | |
|   display: flex;
 | |
|   flex: 1 1 auto;
 | |
|   flex-direction: row;
 | |
|   justify-content: flex-start;
 | |
|   overflow-x: auto;
 | |
|   position: relative;
 | |
| 
 | |
|   &.unscrollable {
 | |
|     overflow-x: hidden;
 | |
|   }
 | |
| 
 | |
|   &__panels {
 | |
|     display: flex;
 | |
|     justify-content: center;
 | |
|     gap: 16px;
 | |
|     width: 100%;
 | |
|     height: 100%;
 | |
|     min-height: 100vh;
 | |
| 
 | |
|     &__pane {
 | |
|       height: 100%;
 | |
|       overflow: hidden;
 | |
|       pointer-events: none;
 | |
|       display: flex;
 | |
|       justify-content: flex-end;
 | |
|       min-width: 285px;
 | |
| 
 | |
|       &--start {
 | |
|         justify-content: flex-start;
 | |
|       }
 | |
| 
 | |
|       &__inner {
 | |
|         position: fixed;
 | |
|         width: 285px;
 | |
|         pointer-events: auto;
 | |
|         height: 100%;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &__main {
 | |
|       box-sizing: border-box;
 | |
|       width: 100%;
 | |
|       flex: 0 1 auto;
 | |
|       display: flex;
 | |
|       flex-direction: column;
 | |
|       contain: inline-size layout paint style;
 | |
|       container: column / inline-size;
 | |
| 
 | |
|       @media screen and (min-width: $no-gap-breakpoint) {
 | |
|         max-width: 600px;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .ui__navigation-bar {
 | |
|   position: sticky;
 | |
|   bottom: 0;
 | |
|   background: var(--background-color);
 | |
|   backdrop-filter: var(--background-filter);
 | |
|   border-top: 1px solid var(--background-border-color);
 | |
|   z-index: 3;
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   justify-content: space-between;
 | |
|   gap: 8px;
 | |
|   padding-bottom: env(safe-area-inset-bottom);
 | |
| 
 | |
|   .layout-multiple-columns & {
 | |
|     display: none;
 | |
|   }
 | |
| 
 | |
|   &__items {
 | |
|     display: grid;
 | |
|     grid-auto-columns: minmax(0, 1fr);
 | |
|     grid-auto-flow: column;
 | |
|     padding: 0 16px;
 | |
| 
 | |
|     &.active {
 | |
|       flex: 1;
 | |
|       padding: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__sign-up {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     gap: 4px;
 | |
|     padding-inline-start: 16px;
 | |
|   }
 | |
| 
 | |
|   &__item {
 | |
|     display: flex;
 | |
|     flex-direction: column;
 | |
|     align-items: center;
 | |
|     background: transparent;
 | |
|     border: none;
 | |
|     gap: 8px;
 | |
|     font-size: 12px;
 | |
|     font-weight: 500;
 | |
|     line-height: 16px;
 | |
|     padding-top: 11px;
 | |
|     padding-bottom: 15px;
 | |
|     border-top: 4px solid transparent;
 | |
|     text-decoration: none;
 | |
|     color: inherit;
 | |
| 
 | |
|     &.active {
 | |
|       color: $highlight-text-color;
 | |
|     }
 | |
| 
 | |
|     &:focus {
 | |
|       outline: 0;
 | |
|     }
 | |
| 
 | |
|     &:focus-visible {
 | |
|       border-top-color: $ui-button-focus-outline-color;
 | |
|       border-radius: 0;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .tabs-bar__wrapper {
 | |
|   background: var(--background-color);
 | |
|   backdrop-filter: var(--background-filter);
 | |
|   position: sticky;
 | |
|   top: 0;
 | |
|   z-index: 2;
 | |
|   padding-top: 0;
 | |
| 
 | |
|   @media screen and (min-width: $no-gap-breakpoint) {
 | |
|     padding-top: 10px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .react-swipeable-view-container {
 | |
|   &,
 | |
|   .columns-area,
 | |
|   .drawer,
 | |
|   .column {
 | |
|     height: 100%;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .react-swipeable-view-container > * {
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   justify-content: center;
 | |
|   height: 100%;
 | |
| }
 | |
| 
 | |
| .column {
 | |
|   width: clamp(380px, calc((100% - 350px) / 4), 400px);
 | |
|   position: relative;
 | |
|   box-sizing: border-box;
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
| 
 | |
|   > .scrollable {
 | |
|     border: 1px solid var(--background-border-color);
 | |
|     border-top: 0;
 | |
|     border-radius: 0 0 4px 4px;
 | |
| 
 | |
|     &.about,
 | |
|     &.privacy-policy {
 | |
|       border-top: 1px solid var(--background-border-color);
 | |
|       border-radius: 4px;
 | |
| 
 | |
|       @media screen and (max-width: $no-gap-breakpoint) {
 | |
|         border-top: 0;
 | |
|         border-bottom: 0;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .ui {
 | |
|   flex: 0 0 auto;
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
|   width: 100%;
 | |
|   height: 100%;
 | |
| }
 | |
| 
 | |
| .drawer {
 | |
|   width: 350px;
 | |
|   box-sizing: border-box;
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
|   overflow-y: hidden;
 | |
| }
 | |
| 
 | |
| .drawer__tab {
 | |
|   display: flex;
 | |
|   flex: 1 1 auto;
 | |
|   padding: 13px 3px 11px;
 | |
|   color: $darker-text-color;
 | |
|   text-decoration: none;
 | |
|   text-align: center;
 | |
|   font-size: 16px;
 | |
|   align-items: center;
 | |
|   justify-content: center;
 | |
| }
 | |
| 
 | |
| .column,
 | |
| .drawer {
 | |
|   flex: 1 1 100%;
 | |
|   overflow: hidden;
 | |
| }
 | |
| 
 | |
| @media screen and (width > $mobile-breakpoint) {
 | |
|   .columns-area {
 | |
|     padding: 0;
 | |
|   }
 | |
| 
 | |
|   .column,
 | |
|   .drawer {
 | |
|     flex: 0 0 auto;
 | |
|     padding: 10px;
 | |
|     padding-inline-start: 5px;
 | |
|     padding-inline-end: 5px;
 | |
| 
 | |
|     &:first-child {
 | |
|       padding-inline-start: 10px;
 | |
|     }
 | |
| 
 | |
|     &:last-child {
 | |
|       padding-inline-end: 10px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .columns-area > div {
 | |
|     .column,
 | |
|     .drawer {
 | |
|       padding-inline-start: 5px;
 | |
|       padding-inline-end: 5px;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .columns-area--mobile {
 | |
|   flex-direction: column;
 | |
|   width: 100%;
 | |
|   height: 100%;
 | |
|   margin: 0 auto;
 | |
| 
 | |
|   .column,
 | |
|   .drawer {
 | |
|     width: 100%;
 | |
|     height: 100%;
 | |
|     padding: 0;
 | |
|   }
 | |
| 
 | |
|   .account-card {
 | |
|     margin-bottom: 0;
 | |
|   }
 | |
| 
 | |
|   .filter-form {
 | |
|     display: flex;
 | |
|     flex-wrap: wrap;
 | |
|   }
 | |
| 
 | |
|   .autosuggest-textarea__textarea {
 | |
|     font-size: 16px;
 | |
|   }
 | |
| 
 | |
|   .search__input {
 | |
|     line-height: 18px;
 | |
|     font-size: 16px;
 | |
|     padding: 15px;
 | |
|     padding-inline-end: 30px;
 | |
|   }
 | |
| 
 | |
|   .scrollable {
 | |
|     overflow: visible;
 | |
| 
 | |
|     @supports (display: grid) {
 | |
|       contain: content;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   @media screen and (min-width: $no-gap-breakpoint) {
 | |
|     padding: 10px 0;
 | |
|     padding-top: 0;
 | |
|   }
 | |
| }
 | |
| 
 | |
| @media screen and (min-width: $no-gap-breakpoint) {
 | |
|   .react-swipeable-view-container .columns-area--mobile {
 | |
|     height: calc(100% - 10px) !important;
 | |
|   }
 | |
| 
 | |
|   .getting-started__wrapper {
 | |
|     margin-bottom: 10px;
 | |
|   }
 | |
| 
 | |
|   .search-page .search {
 | |
|     display: none;
 | |
|   }
 | |
| 
 | |
|   .navigation-panel__legal,
 | |
|   .navigation-panel__compose-button,
 | |
|   .navigation-panel .navigation-bar {
 | |
|     display: none !important;
 | |
|   }
 | |
| }
 | |
| 
 | |
| @media screen and (max-width: $no-gap-breakpoint - 1px) {
 | |
|   $sidebar-width: 285px;
 | |
| 
 | |
|   .columns-area__panels__main {
 | |
|     width: calc(100% - $sidebar-width);
 | |
|   }
 | |
| 
 | |
|   .columns-area__panels {
 | |
|     min-height: 100vh;
 | |
|     gap: 0;
 | |
|   }
 | |
| 
 | |
|   .columns-area__panels__pane--navigational {
 | |
|     min-width: $sidebar-width;
 | |
| 
 | |
|     .columns-area__panels__pane__inner {
 | |
|       width: $sidebar-width;
 | |
|     }
 | |
| 
 | |
|     .navigation-panel {
 | |
|       margin: 0;
 | |
|       border-inline-start: 1px solid var(--background-border-color);
 | |
|       height: 100vh;
 | |
|     }
 | |
| 
 | |
|     .navigation-panel__sign-in-banner,
 | |
|     .navigation-panel__banner,
 | |
|     .getting-started__trends,
 | |
|     .navigation-panel__logo {
 | |
|       display: none;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .layout-single-column {
 | |
|     .column > .scrollable,
 | |
|     .tabs-bar__wrapper .column-header,
 | |
|     .tabs-bar__wrapper .column-back-button,
 | |
|     .explore__search-header,
 | |
|     .column-search-header {
 | |
|       border-left: 0;
 | |
|       border-right: 0;
 | |
|     }
 | |
| 
 | |
|     .column-header,
 | |
|     .column-back-button,
 | |
|     .scrollable,
 | |
|     .error-column {
 | |
|       border-radius: 0 !important;
 | |
|     }
 | |
| 
 | |
|     .column-header,
 | |
|     .column-back-button {
 | |
|       border-top: 0;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| @media screen and (width <= 759px) {
 | |
|   .columns-area__panels__main {
 | |
|     width: 100%;
 | |
|   }
 | |
| 
 | |
|   .columns-area__panels__pane--navigational {
 | |
|     position: fixed;
 | |
|     inset-inline-end: 0;
 | |
|     width: 100%;
 | |
|     height: 100%;
 | |
|     pointer-events: none;
 | |
|   }
 | |
| 
 | |
|   .columns-area__panels__pane--navigational .columns-area__panels__pane__inner {
 | |
|     pointer-events: auto;
 | |
|     background: var(--background-color);
 | |
|     position: fixed;
 | |
|     width: 284px + 70px;
 | |
|     inset-inline-end: -70px;
 | |
|     touch-action: pan-y;
 | |
| 
 | |
|     .navigation-panel {
 | |
|       width: 284px;
 | |
|       overflow-y: auto;
 | |
| 
 | |
|       &__menu {
 | |
|         flex-shrink: 0;
 | |
|         min-height: none;
 | |
|         overflow: hidden;
 | |
|         padding-bottom: calc(65px + env(safe-area-inset-bottom));
 | |
|       }
 | |
| 
 | |
|       &__logo {
 | |
|         display: none;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .columns-area__panels__pane--navigational {
 | |
|   transition: background 500ms;
 | |
| }
 | |
| 
 | |
| .columns-area__panels__pane--overlay {
 | |
|   pointer-events: auto;
 | |
|   background: rgba($base-overlay-background, 0.5);
 | |
| 
 | |
|   .columns-area__panels__pane__inner {
 | |
|     box-shadow: var(--dropdown-shadow);
 | |
|   }
 | |
| }
 | |
| 
 | |
| @media screen and (width >= 760px) {
 | |
|   .ui__navigation-bar {
 | |
|     display: none;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .explore-suggestions-card {
 | |
|   padding: 12px 16px;
 | |
|   gap: 8px;
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
| 
 | |
|   &:last-child {
 | |
|     border-bottom: 0;
 | |
|   }
 | |
| 
 | |
|   &__source {
 | |
|     font-size: 13px;
 | |
|     line-height: 16px;
 | |
|     color: $dark-text-color;
 | |
| 
 | |
|     @container (width >= 400px) {
 | |
|       padding-inline-start: 60px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__body {
 | |
|     display: flex;
 | |
|     gap: 12px;
 | |
|     align-items: center;
 | |
|     justify-content: end;
 | |
|   }
 | |
| 
 | |
|   &__avatar {
 | |
|     flex-shrink: 0;
 | |
| 
 | |
|     @container (width < 360px) {
 | |
|       width: 35px !important;
 | |
|       height: 35px !important;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__link {
 | |
|     flex: 1 1 auto;
 | |
|     display: flex;
 | |
|     gap: 12px;
 | |
|     align-items: center;
 | |
|     text-decoration: none;
 | |
|     min-width: 0;
 | |
| 
 | |
|     &:hover,
 | |
|     &:focus-visible {
 | |
|       .display-name__html {
 | |
|         text-decoration: underline;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .display-name {
 | |
|       font-size: 15px;
 | |
|       line-height: 20px;
 | |
|       color: $secondary-text-color;
 | |
| 
 | |
|       strong {
 | |
|         font-weight: 700;
 | |
|       }
 | |
| 
 | |
|       &__account {
 | |
|         color: $darker-text-color;
 | |
|         display: block;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__actions {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     gap: 8px;
 | |
|     justify-content: end;
 | |
| 
 | |
|     .button {
 | |
|       min-width: 80px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__dismiss-button {
 | |
|     @container (width < 400px) {
 | |
|       display: none;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| @media screen and (max-width: $no-gap-breakpoint - 1px) {
 | |
|   .columns-area__panels__pane--compositional {
 | |
|     display: none;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .icon-with-badge {
 | |
|   display: inline-flex;
 | |
|   position: relative;
 | |
| 
 | |
|   &__badge {
 | |
|     position: absolute;
 | |
|     inset-inline-start: 9px;
 | |
|     top: -13px;
 | |
|     background: $ui-highlight-color;
 | |
|     border: 2px solid var(--background-color);
 | |
|     padding: 1px 6px;
 | |
|     border-radius: 6px;
 | |
|     font-size: 10px;
 | |
|     font-weight: 500;
 | |
|     line-height: 14px;
 | |
|     color: $primary-text-color;
 | |
|   }
 | |
| 
 | |
|   &__issue-badge {
 | |
|     position: absolute;
 | |
|     inset-inline-start: 11px;
 | |
|     bottom: 1px;
 | |
|     display: block;
 | |
|     background: $error-red;
 | |
|     border-radius: 50%;
 | |
|     width: 0.625rem;
 | |
|     height: 0.625rem;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .column-link--transparent .icon-with-badge__badge {
 | |
|   border-color: var(--background-color);
 | |
| }
 | |
| 
 | |
| .column-title {
 | |
|   text-align: center;
 | |
|   padding-bottom: 32px;
 | |
| 
 | |
|   h3 {
 | |
|     font-size: 24px;
 | |
|     line-height: 1.5;
 | |
|     font-weight: 700;
 | |
|     margin-bottom: 10px;
 | |
|   }
 | |
| 
 | |
|   p {
 | |
|     font-size: 16px;
 | |
|     line-height: 24px;
 | |
|     font-weight: 400;
 | |
|     color: $darker-text-color;
 | |
|   }
 | |
| 
 | |
|   @media screen and (width >= 600px) {
 | |
|     padding: 40px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .copy-paste-text {
 | |
|   background: lighten($ui-base-color, 4%);
 | |
|   border-radius: 8px;
 | |
|   border: 1px solid var(--background-border-color);
 | |
|   padding: 16px;
 | |
|   color: $primary-text-color;
 | |
|   font-size: 15px;
 | |
|   line-height: 22px;
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
|   align-items: flex-end;
 | |
|   transition: border-color 300ms linear;
 | |
|   margin-bottom: 30px;
 | |
| 
 | |
|   &:focus,
 | |
|   &.focused {
 | |
|     transition: none;
 | |
|     outline: 0;
 | |
|     border-color: $highlight-text-color;
 | |
|   }
 | |
| 
 | |
|   &.copied {
 | |
|     border-color: $valid-value-color;
 | |
|     transition: none;
 | |
|   }
 | |
| 
 | |
|   textarea {
 | |
|     width: 100%;
 | |
|     height: auto;
 | |
|     background: transparent;
 | |
|     color: inherit;
 | |
|     font: inherit;
 | |
|     border: 0;
 | |
|     padding: 0;
 | |
|     margin-bottom: 30px;
 | |
|     resize: none;
 | |
| 
 | |
|     &:focus {
 | |
|       outline: 0;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .onboarding__profile {
 | |
|   position: relative;
 | |
|   margin-bottom: 40px + 20px;
 | |
|   margin-top: -20px;
 | |
| 
 | |
|   .app-form__avatar-input {
 | |
|     border: 2px solid var(--background-color);
 | |
|     position: absolute;
 | |
|     inset-inline-start: -2px;
 | |
|     bottom: -40px;
 | |
|     z-index: 2;
 | |
|   }
 | |
| 
 | |
|   .app-form__header-input {
 | |
|     margin: 0 -20px;
 | |
|     border-radius: 0;
 | |
| 
 | |
|     img {
 | |
|       border-radius: 0;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .compose-panel {
 | |
|   width: 285px;
 | |
|   margin-top: 10px;
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
|   height: calc(100% - 10px);
 | |
|   overflow-y: hidden;
 | |
| 
 | |
|   .compose-form {
 | |
|     flex: 1 1 auto;
 | |
|     min-height: 0;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .navigation-panel {
 | |
|   margin-top: 10px;
 | |
|   margin-bottom: 10px;
 | |
|   height: calc(100% - 20px);
 | |
|   overflow: hidden;
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
| 
 | |
|   &__menu {
 | |
|     flex: 1 1 auto;
 | |
|     min-height: 0;
 | |
|     overflow-y: auto;
 | |
|   }
 | |
| 
 | |
|   &__list-panel {
 | |
|     &__header {
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       padding-inline-end: 12px;
 | |
| 
 | |
|       .column-link {
 | |
|         flex: 1 1 auto;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &__items {
 | |
|       padding-inline-start: 24px + 5px;
 | |
| 
 | |
|       .icon {
 | |
|         display: none;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__compose-button {
 | |
|     display: flex;
 | |
|     justify-content: flex-start;
 | |
|     padding-top: 10px;
 | |
|     padding-bottom: 10px;
 | |
|     padding-inline-start: 13px - 7px;
 | |
|     padding-inline-end: 13px;
 | |
|     gap: 5px;
 | |
|     margin: 12px;
 | |
|     margin-bottom: 4px;
 | |
|     border-radius: 6px;
 | |
| 
 | |
|     .icon {
 | |
|       width: 24px;
 | |
|       height: 24px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .navigation-bar {
 | |
|     padding: 16px;
 | |
|     border-bottom: 1px solid var(--background-border-color);
 | |
|   }
 | |
| 
 | |
|   .logo {
 | |
|     height: 30px;
 | |
|     width: auto;
 | |
|   }
 | |
| 
 | |
|   &__logo {
 | |
|     margin-bottom: 12px;
 | |
|   }
 | |
| 
 | |
|   @media screen and (height <= 710px) {
 | |
|     &__portal {
 | |
|       display: none;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   @media screen and (height <= 765px) {
 | |
|     &__portal .trends__item:nth-child(n + 3) {
 | |
|       display: none;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   @media screen and (height <= 820px) {
 | |
|     &__portal .trends__item:nth-child(n + 4) {
 | |
|       display: none;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   @media screen and (height <= 920px) {
 | |
|     .column-link.column-link--optional {
 | |
|       display: none;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .navigation-panel,
 | |
| .compose-panel {
 | |
|   hr {
 | |
|     flex: 0 0 auto;
 | |
|     border: 0;
 | |
|     background: transparent;
 | |
|     border-top: 1px solid var(--background-border-color);
 | |
|     margin: 10px 0;
 | |
|   }
 | |
| 
 | |
|   .flex-spacer {
 | |
|     background: transparent;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .drawer__pager {
 | |
|   box-sizing: border-box;
 | |
|   padding: 0;
 | |
|   flex-grow: 1;
 | |
|   position: relative;
 | |
|   overflow: hidden;
 | |
|   display: flex;
 | |
|   border-radius: 4px;
 | |
|   border: 1px solid var(--background-border-color);
 | |
| }
 | |
| 
 | |
| .drawer__inner {
 | |
|   position: absolute;
 | |
|   top: 0;
 | |
|   inset-inline-start: 0;
 | |
|   background: var(--background-color);
 | |
|   box-sizing: border-box;
 | |
|   padding: 0;
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
|   overflow: hidden;
 | |
|   overflow-y: auto;
 | |
|   width: 100%;
 | |
|   height: 100%;
 | |
|   z-index: 0;
 | |
| }
 | |
| 
 | |
| .drawer__inner__mastodon {
 | |
|   background: var(--background-color)
 | |
|     url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 234.80078 31.757813" width="234.80078" height="31.757812"><path d="M19.599609 0c-1.05 0-2.10039.375-2.90039 1.125L0 16.925781v14.832031h234.80078V17.025391l-16.5-15.900391c-1.6-1.5-4.20078-1.5-5.80078 0l-13.80078 13.099609c-1.6 1.5-4.19883 1.5-5.79883 0L179.09961 1.125c-1.6-1.5-4.19883-1.5-5.79883 0L159.5 14.224609c-1.6 1.5-4.20078 1.5-5.80078 0L139.90039 1.125c-1.6-1.5-4.20078-1.5-5.80078 0l-13.79883 13.099609c-1.6 1.5-4.20078 1.5-5.80078 0L100.69922 1.125c-1.600001-1.5-4.198829-1.5-5.798829 0l-13.59961 13.099609c-1.6 1.5-4.200781 1.5-5.800781 0L61.699219 1.125c-1.6-1.5-4.198828-1.5-5.798828 0L42.099609 14.224609c-1.6 1.5-4.198828 1.5-5.798828 0L22.5 1.125C21.7.375 20.649609 0 19.599609 0z" fill="#{hex-color(darken($ui-base-color, 4%))}"/></svg>')
 | |
|     no-repeat bottom / 100% auto;
 | |
|   flex: 1;
 | |
|   min-height: 47px;
 | |
|   display: none;
 | |
| 
 | |
|   > img {
 | |
|     display: block;
 | |
|     object-fit: contain;
 | |
|     object-position: bottom left;
 | |
|     width: 85%;
 | |
|     height: 100%;
 | |
|     pointer-events: none;
 | |
|     user-select: none;
 | |
|   }
 | |
| 
 | |
|   @media screen and (height >= 640px) {
 | |
|     display: block;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .drawer__header {
 | |
|   flex: 0 0 auto;
 | |
|   font-size: 16px;
 | |
|   border: 1px solid var(--background-border-color);
 | |
|   margin-bottom: 10px;
 | |
|   display: flex;
 | |
|   flex-direction: row;
 | |
|   border-radius: 4px;
 | |
|   overflow: hidden;
 | |
| 
 | |
|   a:hover,
 | |
|   a:focus,
 | |
|   a:active {
 | |
|     color: $primary-text-color;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .scrollable {
 | |
|   overflow-y: scroll;
 | |
|   overflow-x: hidden;
 | |
|   flex: 1 1 auto;
 | |
|   -webkit-overflow-scrolling: touch;
 | |
| 
 | |
|   &.optionally-scrollable {
 | |
|     overflow-y: auto;
 | |
|   }
 | |
| 
 | |
|   @supports (display: grid) {
 | |
|     // hack to fix Chrome <57
 | |
|     contain: strict;
 | |
|   }
 | |
| 
 | |
|   &--flex {
 | |
|     display: flex;
 | |
|     flex-direction: column;
 | |
|   }
 | |
| 
 | |
|   &__append {
 | |
|     flex: 1 1 auto;
 | |
|     position: relative;
 | |
|     min-height: 120px;
 | |
|   }
 | |
| 
 | |
|   .scrollable {
 | |
|     flex: 1 1 auto;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .scrollable.fullscreen {
 | |
|   @supports (display: grid) {
 | |
|     // hack to fix Chrome <57
 | |
|     contain: none;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .column-back-button {
 | |
|   box-sizing: border-box;
 | |
|   width: 100%;
 | |
|   background: transparent;
 | |
|   border: 1px solid var(--background-border-color);
 | |
|   border-radius: 4px 4px 0 0;
 | |
|   color: $highlight-text-color;
 | |
|   cursor: pointer;
 | |
|   flex: 0 0 auto;
 | |
|   font-size: 16px;
 | |
|   line-height: inherit;
 | |
|   text-align: unset;
 | |
|   padding: 13px;
 | |
|   margin: 0;
 | |
|   z-index: 3;
 | |
|   outline: 0;
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   gap: 5px;
 | |
| 
 | |
|   &:hover {
 | |
|     text-decoration: underline;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .column-header__back-button {
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   gap: 5px;
 | |
|   background: transparent;
 | |
|   border: 0;
 | |
|   font-family: inherit;
 | |
|   color: $highlight-text-color;
 | |
|   cursor: pointer;
 | |
|   white-space: nowrap;
 | |
|   font-size: 16px;
 | |
|   padding: 13px;
 | |
|   z-index: 3;
 | |
| 
 | |
|   &:hover {
 | |
|     text-decoration: underline;
 | |
|   }
 | |
| 
 | |
|   &.compact {
 | |
|     padding-inline-end: 5px;
 | |
|     flex: 0 0 auto;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .react-toggle {
 | |
|   display: inline-block;
 | |
|   position: relative;
 | |
|   cursor: pointer;
 | |
|   background-color: transparent;
 | |
|   border: 0;
 | |
|   border-radius: 10px;
 | |
|   padding: 0;
 | |
|   user-select: none;
 | |
|   -webkit-tap-highlight-color: rgba($base-overlay-background, 0);
 | |
|   -webkit-tap-highlight-color: transparent;
 | |
| }
 | |
| 
 | |
| .react-toggle-screenreader-only,
 | |
| .sr-only {
 | |
|   border: 0;
 | |
|   clip: rect(0 0 0 0);
 | |
|   height: 1px;
 | |
|   margin: -1px;
 | |
|   overflow: hidden;
 | |
|   padding: 0;
 | |
|   position: absolute;
 | |
|   width: 1px;
 | |
| }
 | |
| 
 | |
| .react-toggle--disabled {
 | |
|   cursor: not-allowed;
 | |
|   opacity: 0.5;
 | |
|   transition: opacity 0.25s;
 | |
| }
 | |
| 
 | |
| .react-toggle-track {
 | |
|   width: 32px;
 | |
|   height: 20px;
 | |
|   padding: 0;
 | |
|   border-radius: 10px;
 | |
|   background-color: $ui-primary-color;
 | |
| }
 | |
| 
 | |
| .react-toggle--focus {
 | |
|   outline: $ui-button-focus-outline;
 | |
| }
 | |
| 
 | |
| .react-toggle--checked .react-toggle-track {
 | |
|   background-color: $ui-highlight-color;
 | |
| }
 | |
| 
 | |
| .react-toggle-track-check,
 | |
| .react-toggle-track-x {
 | |
|   display: none;
 | |
| }
 | |
| 
 | |
| .react-toggle-thumb {
 | |
|   position: absolute;
 | |
|   top: 2px;
 | |
|   inset-inline-start: 2px;
 | |
|   width: 16px;
 | |
|   height: 16px;
 | |
|   border-radius: 50%;
 | |
|   background-color: $ui-button-color;
 | |
|   box-sizing: border-box;
 | |
|   transition: all 0.25s ease;
 | |
|   transition-property: border-color, left;
 | |
| }
 | |
| 
 | |
| .react-toggle--checked .react-toggle-thumb {
 | |
|   inset-inline-start: 32px - 16px - 2px;
 | |
|   border-color: $ui-highlight-color;
 | |
| }
 | |
| 
 | |
| .react-toggle:hover:not(.react-toggle--disabled) .react-toggle-track {
 | |
|   background: darken($ui-primary-color, 5%);
 | |
| }
 | |
| 
 | |
| .react-toggle.react-toggle--checked:hover:not(.react-toggle--disabled)
 | |
|   .react-toggle-track {
 | |
|   background: lighten($ui-highlight-color, 5%);
 | |
| }
 | |
| 
 | |
| .switch-to-advanced {
 | |
|   color: $light-text-color;
 | |
|   background-color: $ui-base-color;
 | |
|   padding: 15px;
 | |
|   border-radius: 4px;
 | |
|   margin-top: 4px;
 | |
|   margin-bottom: 12px;
 | |
|   font-size: 13px;
 | |
|   line-height: 18px;
 | |
| 
 | |
|   .switch-to-advanced__toggle {
 | |
|     color: $ui-button-tertiary-color;
 | |
|     font-weight: bold;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .column-link {
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   gap: 5px;
 | |
|   font-size: 16px;
 | |
|   padding: 13px;
 | |
|   text-decoration: none;
 | |
|   overflow: hidden;
 | |
|   white-space: nowrap;
 | |
|   border: 0;
 | |
|   background: transparent;
 | |
|   color: $secondary-text-color;
 | |
|   border-left: 4px solid transparent;
 | |
| 
 | |
|   &:hover,
 | |
|   &:focus,
 | |
|   &:active {
 | |
|     color: $primary-text-color;
 | |
|   }
 | |
| 
 | |
|   &.active {
 | |
|     color: $highlight-text-color;
 | |
|   }
 | |
| 
 | |
|   &:focus {
 | |
|     outline: 0;
 | |
|   }
 | |
| 
 | |
|   &:focus-visible {
 | |
|     border-color: $ui-button-focus-outline-color;
 | |
|     border-radius: 0;
 | |
|   }
 | |
| 
 | |
|   &--logo {
 | |
|     background: transparent;
 | |
|     padding: 10px;
 | |
| 
 | |
|     &:hover,
 | |
|     &:focus,
 | |
|     &:active {
 | |
|       background: transparent;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .column-link__badge {
 | |
|   display: inline-block;
 | |
|   border-radius: 4px;
 | |
|   font-size: 12px;
 | |
|   line-height: 19px;
 | |
|   font-weight: 500;
 | |
|   background: $ui-base-color;
 | |
|   padding: 4px 8px;
 | |
|   margin: -6px 10px;
 | |
| }
 | |
| 
 | |
| .column-subheading {
 | |
|   background: var(--surface-background-color);
 | |
|   color: $darker-text-color;
 | |
|   padding: 8px 20px;
 | |
|   font-size: 12px;
 | |
|   font-weight: 500;
 | |
|   text-transform: uppercase;
 | |
|   cursor: default;
 | |
| }
 | |
| 
 | |
| .getting-started__wrapper {
 | |
|   flex: 0 0 auto;
 | |
| }
 | |
| 
 | |
| .flex-spacer {
 | |
|   flex: 1 1 auto;
 | |
| }
 | |
| 
 | |
| .getting-started {
 | |
|   color: $dark-text-color;
 | |
|   overflow: auto;
 | |
|   border: 1px solid var(--background-border-color);
 | |
|   border-top: 0;
 | |
| 
 | |
|   &__trends {
 | |
|     flex: 0 1 auto;
 | |
|     opacity: 1;
 | |
|     animation: fade 150ms linear;
 | |
|     margin-top: 10px;
 | |
| 
 | |
|     h4 {
 | |
|       border-bottom: 1px solid var(--background-border-color);
 | |
|       padding: 10px;
 | |
|       font-size: 12px;
 | |
|       text-transform: uppercase;
 | |
|       font-weight: 500;
 | |
| 
 | |
|       a {
 | |
|         color: $darker-text-color;
 | |
|         text-decoration: none;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .trends__item {
 | |
|       border-bottom: 0;
 | |
|       padding: 10px;
 | |
| 
 | |
|       &__current {
 | |
|         color: $darker-text-color;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .keyboard-shortcuts {
 | |
|   padding: 8px 0 0;
 | |
|   overflow: hidden;
 | |
| 
 | |
|   thead {
 | |
|     position: absolute;
 | |
|     inset-inline-start: -9999px;
 | |
|   }
 | |
| 
 | |
|   td {
 | |
|     padding: 0 10px 8px;
 | |
|   }
 | |
| 
 | |
|   kbd {
 | |
|     display: inline-block;
 | |
|     padding: 3px 5px;
 | |
|     background-color: lighten($ui-base-color, 8%);
 | |
|     border: 1px solid darken($ui-base-color, 4%);
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status-card {
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   position: relative;
 | |
|   font-size: 14px;
 | |
|   color: $darker-text-color;
 | |
|   margin-top: 14px;
 | |
|   text-decoration: none;
 | |
|   overflow: hidden;
 | |
|   border: 1px solid var(--background-border-color);
 | |
|   border-radius: 8px;
 | |
|   contain: inline-size layout paint style;
 | |
| 
 | |
|   &.bottomless {
 | |
|     border-radius: 8px 8px 0 0;
 | |
|   }
 | |
| 
 | |
|   &__actions {
 | |
|     bottom: 0;
 | |
|     inset-inline-start: 0;
 | |
|     position: absolute;
 | |
|     inset-inline-end: 0;
 | |
|     top: 0;
 | |
|     display: flex;
 | |
|     justify-content: center;
 | |
|     align-items: center;
 | |
|     cursor: pointer;
 | |
| 
 | |
|     & > div {
 | |
|       background: rgba($base-shadow-color, 0.6);
 | |
|       border-radius: 8px;
 | |
|       padding: 12px 9px;
 | |
|       backdrop-filter: blur(10px) saturate(180%) contrast(75%) brightness(70%);
 | |
|       flex: 0 0 auto;
 | |
|       display: flex;
 | |
|       justify-content: center;
 | |
|       align-items: center;
 | |
|     }
 | |
| 
 | |
|     button,
 | |
|     a {
 | |
|       display: inline;
 | |
|       color: $secondary-text-color;
 | |
|       background: transparent;
 | |
|       border: 0;
 | |
|       padding: 0 8px;
 | |
|       text-decoration: none;
 | |
|       font-size: 18px;
 | |
|       line-height: 18px;
 | |
| 
 | |
|       &:hover,
 | |
|       &:active,
 | |
|       &:focus {
 | |
|         color: $primary-text-color;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     a {
 | |
|       font-size: 19px;
 | |
|       position: relative;
 | |
|       bottom: -1px;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| a.status-card {
 | |
|   cursor: pointer;
 | |
| 
 | |
|   &:hover,
 | |
|   &:focus,
 | |
|   &:active {
 | |
|     .status-card__title,
 | |
|     .status-card__host,
 | |
|     .status-card__author,
 | |
|     .status-card__description {
 | |
|       color: $highlight-text-color;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status-card a {
 | |
|   color: inherit;
 | |
|   text-decoration: none;
 | |
| 
 | |
|   &:hover,
 | |
|   &:focus,
 | |
|   &:active {
 | |
|     .status-card__title,
 | |
|     .status-card__host,
 | |
|     .status-card__author,
 | |
|     .status-card__description {
 | |
|       color: $highlight-text-color;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status-card-photo {
 | |
|   cursor: zoom-in;
 | |
|   display: block;
 | |
|   text-decoration: none;
 | |
|   width: 100%;
 | |
|   height: auto;
 | |
|   margin: 0;
 | |
| }
 | |
| 
 | |
| .status-card-video {
 | |
|   // Firefox has a bug where frameborder=0 iframes add some extra blank space
 | |
|   // see https://bugzilla.mozilla.org/show_bug.cgi?id=155174
 | |
|   overflow: hidden;
 | |
| 
 | |
|   iframe {
 | |
|     width: 100%;
 | |
|     height: 100%;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status-card__title {
 | |
|   display: block;
 | |
|   font-weight: 700;
 | |
|   font-size: 19px;
 | |
|   line-height: 24px;
 | |
|   color: $primary-text-color;
 | |
|   overflow: hidden;
 | |
|   white-space: nowrap;
 | |
|   text-overflow: ellipsis;
 | |
| }
 | |
| 
 | |
| .status-card.expanded .status-card__title {
 | |
|   white-space: normal;
 | |
|   display: -webkit-box;
 | |
|   -webkit-line-clamp: 2;
 | |
|   -webkit-box-orient: vertical;
 | |
| }
 | |
| 
 | |
| .status-card__content {
 | |
|   flex: 1 1 auto;
 | |
|   overflow: hidden;
 | |
|   padding: 15px;
 | |
|   box-sizing: border-box;
 | |
|   max-width: 100%;
 | |
| }
 | |
| 
 | |
| .status-card__host {
 | |
|   display: block;
 | |
|   font-size: 14px;
 | |
|   margin-bottom: 8px;
 | |
|   white-space: nowrap;
 | |
|   overflow: hidden;
 | |
|   text-overflow: ellipsis;
 | |
| }
 | |
| 
 | |
| .status-card__author {
 | |
|   display: block;
 | |
|   margin-top: 8px;
 | |
|   font-size: 14px;
 | |
|   color: $primary-text-color;
 | |
|   white-space: nowrap;
 | |
|   overflow: hidden;
 | |
|   text-overflow: ellipsis;
 | |
| 
 | |
|   strong {
 | |
|     font-weight: 500;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status-card__description {
 | |
|   display: block;
 | |
|   margin-top: 8px;
 | |
|   font-size: 14px;
 | |
|   white-space: nowrap;
 | |
|   overflow: hidden;
 | |
|   text-overflow: ellipsis;
 | |
| }
 | |
| 
 | |
| .status-card__image {
 | |
|   flex: 0 0 auto;
 | |
|   width: 120px;
 | |
|   aspect-ratio: 1;
 | |
|   background: lighten($ui-base-color, 8%);
 | |
|   position: relative;
 | |
| 
 | |
|   & > .icon {
 | |
|     width: 18px;
 | |
|     height: 18px;
 | |
|     position: absolute;
 | |
|     transform-origin: 50% 50%;
 | |
|     top: 50%;
 | |
|     inset-inline-start: 50%;
 | |
|     transform: translate(-50%, -50%);
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status-card__image-image {
 | |
|   display: block;
 | |
|   margin: 0;
 | |
|   width: 100%;
 | |
|   height: 100%;
 | |
|   object-fit: cover;
 | |
|   background-size: cover;
 | |
|   background-position: center center;
 | |
| }
 | |
| 
 | |
| .status-card__image-preview {
 | |
|   display: block;
 | |
|   margin: 0;
 | |
|   width: 100%;
 | |
|   height: 100%;
 | |
|   object-fit: fill;
 | |
|   position: absolute;
 | |
|   top: 0;
 | |
|   inset-inline-start: 0;
 | |
|   z-index: 0;
 | |
|   background: $base-overlay-background;
 | |
| 
 | |
|   &--hidden {
 | |
|     display: none;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .status-card.expanded {
 | |
|   flex-direction: column;
 | |
|   align-items: flex-start;
 | |
| }
 | |
| 
 | |
| .status-card.expanded .status-card__image {
 | |
|   width: 100%;
 | |
|   aspect-ratio: auto;
 | |
| }
 | |
| 
 | |
| .status-card__image,
 | |
| .status-card__image-image,
 | |
| .status-card__image-preview {
 | |
|   border-start-start-radius: 8px;
 | |
|   border-start-end-radius: 0;
 | |
|   border-end-end-radius: 0;
 | |
|   border-end-start-radius: 8px;
 | |
| }
 | |
| 
 | |
| .status-card.expanded .status-card__image,
 | |
| .status-card.expanded .status-card__image-image,
 | |
| .status-card.expanded .status-card__image-preview {
 | |
|   border-start-end-radius: 8px;
 | |
|   border-end-end-radius: 0;
 | |
|   border-end-start-radius: 0;
 | |
| }
 | |
| 
 | |
| .status-card.bottomless .status-card__image,
 | |
| .status-card.bottomless .status-card__image-image,
 | |
| .status-card.bottomless .status-card__image-preview {
 | |
|   border-end-end-radius: 0;
 | |
|   border-end-start-radius: 0;
 | |
| }
 | |
| 
 | |
| .status-card.expanded > a {
 | |
|   width: 100%;
 | |
| }
 | |
| 
 | |
| .load-more {
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   justify-content: center;
 | |
|   color: $dark-text-color;
 | |
|   background-color: transparent;
 | |
|   border: 0;
 | |
|   font-size: inherit;
 | |
|   line-height: inherit;
 | |
|   width: 100%;
 | |
|   padding: 15px;
 | |
|   box-sizing: border-box;
 | |
|   text-decoration: none;
 | |
| 
 | |
|   &:hover {
 | |
|     background: var(--on-surface-color);
 | |
|   }
 | |
| 
 | |
|   .icon {
 | |
|     width: 22px;
 | |
|     height: 22px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .load-gap {
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
| }
 | |
| 
 | |
| .timeline-hint {
 | |
|   text-align: center;
 | |
|   color: $dark-text-color;
 | |
|   padding: 16px;
 | |
|   box-sizing: border-box;
 | |
|   width: 100%;
 | |
|   font-size: 14px;
 | |
|   line-height: 21px;
 | |
| 
 | |
|   strong {
 | |
|     font-weight: 500;
 | |
|   }
 | |
| 
 | |
|   a {
 | |
|     color: $highlight-text-color;
 | |
|     text-decoration: none;
 | |
| 
 | |
|     &:hover,
 | |
|     &:focus,
 | |
|     &:active {
 | |
|       text-decoration: underline;
 | |
|       color: lighten($highlight-text-color, 4%);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &--with-descendants {
 | |
|     border-top: 1px solid var(--background-border-color);
 | |
|   }
 | |
| }
 | |
| 
 | |
| .regeneration-indicator {
 | |
|   color: $darker-text-color;
 | |
|   border: 1px solid var(--background-border-color);
 | |
|   border-top: 0;
 | |
|   cursor: default;
 | |
|   display: flex;
 | |
|   flex: 1 1 auto;
 | |
|   flex-direction: column;
 | |
|   align-items: center;
 | |
|   justify-content: center;
 | |
|   padding: 20px;
 | |
| 
 | |
|   &__figure {
 | |
|     display: block;
 | |
|     width: 100%;
 | |
|     height: auto;
 | |
|     max-width: 350px;
 | |
|     margin-top: -50px;
 | |
|   }
 | |
| 
 | |
|   &__label {
 | |
|     text-align: center;
 | |
|     font-size: 16px;
 | |
| 
 | |
|     strong {
 | |
|       font-weight: 500;
 | |
|       display: block;
 | |
|       margin-bottom: 10px;
 | |
|       color: $darker-text-color;
 | |
|     }
 | |
| 
 | |
|     span {
 | |
|       font-size: 15px;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .column-header__wrapper {
 | |
|   position: relative;
 | |
|   flex: 0 0 auto;
 | |
|   z-index: 1;
 | |
| 
 | |
|   &.active {
 | |
|     box-shadow: 0 1px 0 rgba($highlight-text-color, 0.3);
 | |
| 
 | |
|     &::before {
 | |
|       display: block;
 | |
|       content: '';
 | |
|       position: absolute;
 | |
|       bottom: -13px;
 | |
|       inset-inline-start: 0;
 | |
|       inset-inline-end: 0;
 | |
|       margin: 0 auto;
 | |
|       width: 60%;
 | |
|       pointer-events: none;
 | |
|       height: 28px;
 | |
|       z-index: 1;
 | |
|       background: radial-gradient(
 | |
|         ellipse,
 | |
|         rgba($ui-highlight-color, 0.23) 0%,
 | |
|         rgba($ui-highlight-color, 0) 60%
 | |
|       );
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .announcements {
 | |
|     z-index: 1;
 | |
|     position: relative;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .column-header__select-row {
 | |
|   border-width: 0 1px 1px;
 | |
|   border-style: solid;
 | |
|   border-color: var(--background-border-color);
 | |
|   padding: 15px;
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   gap: 8px;
 | |
| 
 | |
|   &__checkbox .check-box {
 | |
|     display: flex;
 | |
|   }
 | |
| 
 | |
|   &__select-menu:disabled {
 | |
|     visibility: hidden;
 | |
|   }
 | |
| 
 | |
|   &__mode-button {
 | |
|     margin-left: auto;
 | |
|     color: $highlight-text-color;
 | |
|     font-weight: bold;
 | |
|     font-size: 14px;
 | |
| 
 | |
|     &:hover {
 | |
|       color: lighten($highlight-text-color, 6%);
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .column-header {
 | |
|   display: flex;
 | |
|   font-size: 16px;
 | |
|   border: 1px solid var(--background-border-color);
 | |
|   border-radius: 4px 4px 0 0;
 | |
|   flex: 0 0 auto;
 | |
|   cursor: pointer;
 | |
|   position: relative;
 | |
|   z-index: 2;
 | |
|   outline: 0;
 | |
| 
 | |
|   &__title {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     gap: 5px;
 | |
|     margin: 0;
 | |
|     border: 0;
 | |
|     padding: 13px;
 | |
|     padding-inline-end: 0;
 | |
|     color: inherit;
 | |
|     background: transparent;
 | |
|     font: inherit;
 | |
|     text-align: start;
 | |
|     text-overflow: ellipsis;
 | |
|     overflow: hidden;
 | |
|     white-space: nowrap;
 | |
|     flex: 1;
 | |
| 
 | |
|     &:focus-visible {
 | |
|       outline: $ui-button-icon-focus-outline;
 | |
|     }
 | |
| 
 | |
|     .logo {
 | |
|       height: 24px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .column-header__back-button + &__title {
 | |
|     padding-inline-start: 0;
 | |
|   }
 | |
| 
 | |
|   .column-header__back-button {
 | |
|     flex: 1;
 | |
|     color: $highlight-text-color;
 | |
| 
 | |
|     &.compact {
 | |
|       flex: 0 0 auto;
 | |
|       color: $primary-text-color;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.active {
 | |
|     .column-header__icon {
 | |
|       color: $highlight-text-color;
 | |
|       text-shadow: 0 0 10px rgba($highlight-text-color, 0.4);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &:focus,
 | |
|   &:active {
 | |
|     outline: 0;
 | |
|   }
 | |
| 
 | |
|   &__advanced-buttons {
 | |
|     display: flex;
 | |
|     justify-content: space-between;
 | |
|     align-items: center;
 | |
|     padding: 16px;
 | |
|     padding-top: 0;
 | |
| 
 | |
|     &:first-child {
 | |
|       padding-top: 16px;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .column-header__buttons {
 | |
|   height: 48px;
 | |
|   display: flex;
 | |
| }
 | |
| 
 | |
| .column-header__links {
 | |
|   margin-bottom: 14px;
 | |
| }
 | |
| 
 | |
| .column-header__links .text-btn {
 | |
|   margin-inline-end: 10px;
 | |
| }
 | |
| 
 | |
| .column-header__button {
 | |
|   display: flex;
 | |
|   justify-content: center;
 | |
|   align-items: center;
 | |
|   border: 0;
 | |
|   color: $darker-text-color;
 | |
|   background: transparent;
 | |
|   cursor: pointer;
 | |
|   font-size: 16px;
 | |
|   padding: 0 15px;
 | |
| 
 | |
|   &:last-child {
 | |
|     border-start-end-radius: 4px;
 | |
|   }
 | |
| 
 | |
|   &:hover {
 | |
|     color: lighten($darker-text-color, 4%);
 | |
|   }
 | |
| 
 | |
|   &:focus-visible {
 | |
|     outline: $ui-button-focus-outline;
 | |
|   }
 | |
| 
 | |
|   &.active {
 | |
|     color: $primary-text-color;
 | |
| 
 | |
|     &:hover {
 | |
|       color: $primary-text-color;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &:disabled {
 | |
|     color: $dark-text-color;
 | |
|     cursor: default;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .no-reduce-motion .column-header__button .icon-sliders {
 | |
|   transition: transform 150ms ease-in-out;
 | |
| }
 | |
| 
 | |
| .column-header__collapsible {
 | |
|   max-height: 70vh;
 | |
|   overflow: hidden;
 | |
|   overflow-y: auto;
 | |
|   color: $darker-text-color;
 | |
|   transition:
 | |
|     max-height 150ms ease-in-out,
 | |
|     opacity 300ms linear;
 | |
|   opacity: 1;
 | |
|   z-index: 1;
 | |
|   position: relative;
 | |
|   border-left: 1px solid var(--background-border-color);
 | |
|   border-right: 1px solid var(--background-border-color);
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
| 
 | |
|   @media screen and (max-width: $no-gap-breakpoint) {
 | |
|     border-left: 0;
 | |
|     border-right: 0;
 | |
|   }
 | |
| 
 | |
|   &.collapsed {
 | |
|     max-height: 0;
 | |
|     opacity: 0.5;
 | |
|     border-bottom: 0;
 | |
|   }
 | |
| 
 | |
|   &.animating {
 | |
|     overflow-y: hidden;
 | |
|   }
 | |
| 
 | |
|   hr {
 | |
|     height: 0;
 | |
|     background: transparent;
 | |
|     border: 0;
 | |
|     border-top: 1px solid var(--background-border-color);
 | |
|     margin: 10px 0;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .column-header__collapsible-inner {
 | |
|   border-top: 0;
 | |
| }
 | |
| 
 | |
| .column-header__setting-btn {
 | |
|   &:hover,
 | |
|   &:focus {
 | |
|     color: $darker-text-color;
 | |
|     text-decoration: underline;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .column-header__collapsible__extra + .column-header__setting-btn {
 | |
|   padding-top: 5px;
 | |
| }
 | |
| 
 | |
| .column-header__permission-btn {
 | |
|   display: inline;
 | |
|   font-weight: inherit;
 | |
|   text-decoration: underline;
 | |
| }
 | |
| 
 | |
| .column-header__setting-arrows {
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
| }
 | |
| 
 | |
| .text-btn {
 | |
|   display: inline-flex;
 | |
|   align-items: center;
 | |
|   gap: 4px;
 | |
|   padding: 0;
 | |
|   font-family: inherit;
 | |
|   font-size: inherit;
 | |
|   font-weight: inherit;
 | |
|   color: inherit;
 | |
|   border: 0;
 | |
|   background: transparent;
 | |
|   cursor: pointer;
 | |
|   text-decoration: none;
 | |
| 
 | |
|   .icon {
 | |
|     width: 13px;
 | |
|     height: 13px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .column-header__issue-btn {
 | |
|   color: $warning-red;
 | |
| 
 | |
|   &:hover {
 | |
|     color: $error-red;
 | |
|     text-decoration: underline;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .loading-indicator {
 | |
|   color: $dark-text-color;
 | |
|   font-size: 12px;
 | |
|   font-weight: 400;
 | |
|   text-transform: uppercase;
 | |
|   overflow: visible;
 | |
|   position: absolute;
 | |
|   top: 50%;
 | |
|   inset-inline-start: 50%;
 | |
|   transform: translate(-50%, -50%);
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   justify-content: center;
 | |
| }
 | |
| 
 | |
| .load-more .loading-indicator,
 | |
| .button .loading-indicator {
 | |
|   position: static;
 | |
|   transform: none;
 | |
| 
 | |
|   .circular-progress {
 | |
|     color: $primary-text-color;
 | |
|     width: 22px;
 | |
|     height: 22px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .load-more .loading-indicator .circular-progress {
 | |
|   color: lighten($ui-base-color, 26%);
 | |
| }
 | |
| 
 | |
| .circular-progress {
 | |
|   color: lighten($ui-base-color, 26%);
 | |
|   animation: 1.4s linear 0s infinite normal none running simple-rotate;
 | |
| 
 | |
|   circle {
 | |
|     stroke: currentColor;
 | |
|     stroke-dasharray: 80px, 200px;
 | |
|     stroke-dashoffset: 0;
 | |
|     animation: circular-progress 1.4s ease-in-out infinite;
 | |
|   }
 | |
| }
 | |
| 
 | |
| @keyframes circular-progress {
 | |
|   0% {
 | |
|     stroke-dasharray: 1px, 200px;
 | |
|     stroke-dashoffset: 0;
 | |
|   }
 | |
| 
 | |
|   50% {
 | |
|     stroke-dasharray: 100px, 200px;
 | |
|     stroke-dashoffset: -15px;
 | |
|   }
 | |
| 
 | |
|   100% {
 | |
|     stroke-dasharray: 100px, 200px;
 | |
|     stroke-dashoffset: -125px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| @keyframes simple-rotate {
 | |
|   0% {
 | |
|     transform: rotate(0deg);
 | |
|   }
 | |
| 
 | |
|   100% {
 | |
|     transform: rotate(360deg);
 | |
|   }
 | |
| }
 | |
| 
 | |
| @keyframes spring-rotate-in {
 | |
|   0% {
 | |
|     transform: rotate(0deg);
 | |
|   }
 | |
| 
 | |
|   30% {
 | |
|     transform: rotate(-484.8deg);
 | |
|   }
 | |
| 
 | |
|   60% {
 | |
|     transform: rotate(-316.7deg);
 | |
|   }
 | |
| 
 | |
|   90% {
 | |
|     transform: rotate(-375deg);
 | |
|   }
 | |
| 
 | |
|   100% {
 | |
|     transform: rotate(-360deg);
 | |
|   }
 | |
| }
 | |
| 
 | |
| @keyframes spring-rotate-out {
 | |
|   0% {
 | |
|     transform: rotate(-360deg);
 | |
|   }
 | |
| 
 | |
|   30% {
 | |
|     transform: rotate(124.8deg);
 | |
|   }
 | |
| 
 | |
|   60% {
 | |
|     transform: rotate(-43.27deg);
 | |
|   }
 | |
| 
 | |
|   90% {
 | |
|     transform: rotate(15deg);
 | |
|   }
 | |
| 
 | |
|   100% {
 | |
|     transform: rotate(0deg);
 | |
|   }
 | |
| }
 | |
| 
 | |
| .video-error-cover {
 | |
|   align-items: center;
 | |
|   background: $base-overlay-background;
 | |
|   color: $primary-text-color;
 | |
|   cursor: pointer;
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
|   height: 100%;
 | |
|   justify-content: center;
 | |
|   margin-top: 8px;
 | |
|   position: relative;
 | |
|   text-align: center;
 | |
|   z-index: 100;
 | |
| }
 | |
| 
 | |
| .spoiler-button {
 | |
|   top: 0;
 | |
|   inset-inline-start: 0;
 | |
|   width: 100%;
 | |
|   height: 100%;
 | |
|   position: absolute;
 | |
|   z-index: 100;
 | |
| 
 | |
|   &--hidden {
 | |
|     display: none;
 | |
|   }
 | |
| 
 | |
|   &--click-thru {
 | |
|     pointer-events: none;
 | |
|   }
 | |
| 
 | |
|   &__overlay {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     justify-content: center;
 | |
|     background: transparent;
 | |
|     width: 100%;
 | |
|     height: 100%;
 | |
|     padding: 0;
 | |
|     margin: 0;
 | |
|     border: 0;
 | |
|     color: $white;
 | |
|     line-height: 20px;
 | |
|     font-size: 14px;
 | |
| 
 | |
|     &__label {
 | |
|       background-color: rgba($black, 0.45);
 | |
|       backdrop-filter: blur(10px) saturate(180%) contrast(75%) brightness(70%);
 | |
|       border-radius: 8px;
 | |
|       padding: 12px 16px;
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       justify-content: center;
 | |
|       gap: 4px;
 | |
|       flex-direction: column;
 | |
|       font-weight: 600;
 | |
|     }
 | |
| 
 | |
|     &__action {
 | |
|       font-weight: 400;
 | |
|       font-size: 13px;
 | |
|     }
 | |
| 
 | |
|     &:hover,
 | |
|     &:focus {
 | |
|       .spoiler-button__overlay__label {
 | |
|         background-color: rgba($black, 0.9);
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .modal-container--preloader {
 | |
|   background: lighten($ui-base-color, 8%);
 | |
| }
 | |
| 
 | |
| .account--panel {
 | |
|   border-top: 1px solid var(--background-border-color);
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
|   display: flex;
 | |
|   flex-direction: row;
 | |
|   padding: 10px 0;
 | |
| }
 | |
| 
 | |
| .account--panel__button,
 | |
| .detailed-status__button {
 | |
|   flex: 1 1 auto;
 | |
|   text-align: center;
 | |
| }
 | |
| 
 | |
| .column-settings {
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
| 
 | |
|   &__section {
 | |
|     // FIXME: Legacy
 | |
|     color: $darker-text-color;
 | |
|     cursor: default;
 | |
|     display: block;
 | |
|     font-weight: 500;
 | |
|   }
 | |
| 
 | |
|   .column-header__links {
 | |
|     margin: 0;
 | |
|   }
 | |
| 
 | |
|   section {
 | |
|     padding: 16px;
 | |
|     border-bottom: 1px solid var(--background-border-color);
 | |
| 
 | |
|     &:last-child {
 | |
|       border-bottom: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   h3 {
 | |
|     font-size: 16px;
 | |
|     line-height: 24px;
 | |
|     letter-spacing: 0.5px;
 | |
|     font-weight: 500;
 | |
|     color: $primary-text-color;
 | |
|     margin-bottom: 16px;
 | |
|   }
 | |
| 
 | |
|   &__row {
 | |
|     display: flex;
 | |
|     flex-direction: column;
 | |
|     gap: 12px;
 | |
|   }
 | |
| 
 | |
|   .app-form__toggle {
 | |
|     &__toggle > div {
 | |
|       border: 0;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .column-settings__hashtags {
 | |
|   margin-top: 15px;
 | |
| 
 | |
|   .column-settings__row {
 | |
|     margin-bottom: 15px;
 | |
|   }
 | |
| 
 | |
|   .column-select {
 | |
|     &__control {
 | |
|       @include search-input;
 | |
| 
 | |
|       &::placeholder {
 | |
|         color: lighten($darker-text-color, 4%);
 | |
|       }
 | |
| 
 | |
|       &::-moz-focus-inner {
 | |
|         border: 0;
 | |
|       }
 | |
| 
 | |
|       &::-moz-focus-inner,
 | |
|       &:focus,
 | |
|       &:active {
 | |
|         outline: 0 !important;
 | |
|       }
 | |
| 
 | |
|       &:focus {
 | |
|         background: lighten($ui-base-color, 4%);
 | |
|       }
 | |
| 
 | |
|       @media screen and (width <= 600px) {
 | |
|         font-size: 16px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &__placeholder {
 | |
|       color: $dark-text-color;
 | |
|       padding-inline-start: 2px;
 | |
|       font-size: 12px;
 | |
|     }
 | |
| 
 | |
|     &__value-container {
 | |
|       padding-inline-start: 6px;
 | |
|     }
 | |
| 
 | |
|     &__multi-value {
 | |
|       background: lighten($ui-base-color, 8%);
 | |
| 
 | |
|       &__remove {
 | |
|         cursor: pointer;
 | |
| 
 | |
|         &:hover,
 | |
|         &:active,
 | |
|         &:focus {
 | |
|           background: lighten($ui-base-color, 12%);
 | |
|           color: lighten($darker-text-color, 4%);
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &__multi-value__label,
 | |
|     &__input,
 | |
|     &__input-container {
 | |
|       color: $darker-text-color;
 | |
|     }
 | |
| 
 | |
|     &__clear-indicator,
 | |
|     &__dropdown-indicator {
 | |
|       cursor: pointer;
 | |
|       transition: none;
 | |
|       color: $dark-text-color;
 | |
| 
 | |
|       &:hover,
 | |
|       &:active,
 | |
|       &:focus {
 | |
|         color: lighten($dark-text-color, 4%);
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &__indicator-separator {
 | |
|       background-color: lighten($ui-base-color, 8%);
 | |
|     }
 | |
| 
 | |
|     &__menu {
 | |
|       @include search-popout;
 | |
| 
 | |
|       & {
 | |
|         padding: 0;
 | |
|         background: $ui-secondary-color;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &__menu-list {
 | |
|       padding: 6px;
 | |
|     }
 | |
| 
 | |
|     &__option {
 | |
|       color: $inverted-text-color;
 | |
|       border-radius: 4px;
 | |
|       font-size: 14px;
 | |
| 
 | |
|       &--is-focused,
 | |
|       &--is-selected {
 | |
|         background: darken($ui-secondary-color, 10%);
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .column-settings__row {
 | |
|   .text-btn:not(.column-header__permission-btn) {
 | |
|     margin-bottom: 15px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .setting-toggle {
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   gap: 8px;
 | |
| }
 | |
| 
 | |
| .setting-toggle__label {
 | |
|   color: $darker-text-color;
 | |
| }
 | |
| 
 | |
| .limited-account-hint {
 | |
|   p {
 | |
|     color: $secondary-text-color;
 | |
|     font-size: 15px;
 | |
|     font-weight: 500;
 | |
|     margin-bottom: 20px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .empty-column-indicator,
 | |
| .follow_requests-unlocked_explanation {
 | |
|   color: $dark-text-color;
 | |
|   text-align: center;
 | |
|   padding: 20px;
 | |
|   font-size: 14px;
 | |
|   line-height: 20px;
 | |
|   font-weight: 400;
 | |
|   cursor: default;
 | |
|   display: flex;
 | |
|   flex: 1 1 auto;
 | |
|   align-items: center;
 | |
|   justify-content: center;
 | |
| 
 | |
|   & > span {
 | |
|     max-width: 500px;
 | |
|   }
 | |
| 
 | |
|   a {
 | |
|     color: $highlight-text-color;
 | |
|     text-decoration: none;
 | |
| 
 | |
|     &:hover {
 | |
|       text-decoration: underline;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .empty-column-indicator {
 | |
|   &__arrow {
 | |
|     position: absolute;
 | |
|     top: 50%;
 | |
|     inset-inline-start: 50%;
 | |
|     pointer-events: none;
 | |
|     transform: translate(100%, -100%) rotate(12deg);
 | |
|     transform-origin: center;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .follow_requests-unlocked_explanation {
 | |
|   background: var(--surface-background-color);
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
|   contain: initial;
 | |
|   flex-grow: 0;
 | |
| }
 | |
| 
 | |
| .error-column {
 | |
|   padding: 20px;
 | |
|   border: 1px solid var(--background-border-color);
 | |
|   border-radius: 4px;
 | |
|   display: flex;
 | |
|   flex: 1 1 auto;
 | |
|   align-items: center;
 | |
|   justify-content: center;
 | |
|   flex-direction: column;
 | |
|   cursor: default;
 | |
| 
 | |
|   &__image {
 | |
|     width: 70%;
 | |
|     max-width: 350px;
 | |
|     margin-top: -50px;
 | |
|   }
 | |
| 
 | |
|   &__message {
 | |
|     text-align: center;
 | |
|     color: $darker-text-color;
 | |
|     font-size: 15px;
 | |
|     line-height: 22px;
 | |
| 
 | |
|     h1 {
 | |
|       font-size: 28px;
 | |
|       line-height: 33px;
 | |
|       font-weight: 700;
 | |
|       margin-bottom: 15px;
 | |
|       color: $primary-text-color;
 | |
|     }
 | |
| 
 | |
|     p {
 | |
|       max-width: 48ch;
 | |
|     }
 | |
| 
 | |
|     &__actions {
 | |
|       margin-top: 30px;
 | |
|       display: flex;
 | |
|       gap: 10px;
 | |
|       align-items: center;
 | |
|       justify-content: center;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| @keyframes heartbeat {
 | |
|   0% {
 | |
|     transform: scale(1);
 | |
|     animation-timing-function: ease-out;
 | |
|   }
 | |
| 
 | |
|   10% {
 | |
|     transform: scale(0.91);
 | |
|     animation-timing-function: ease-in;
 | |
|   }
 | |
| 
 | |
|   17% {
 | |
|     transform: scale(0.98);
 | |
|     animation-timing-function: ease-out;
 | |
|   }
 | |
| 
 | |
|   33% {
 | |
|     transform: scale(0.87);
 | |
|     animation-timing-function: ease-in;
 | |
|   }
 | |
| 
 | |
|   45% {
 | |
|     transform: scale(1);
 | |
|     animation-timing-function: ease-out;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .no-reduce-motion .pulse-loading {
 | |
|   transform-origin: center center;
 | |
|   animation: heartbeat 1.5s ease-in-out infinite both;
 | |
| }
 | |
| 
 | |
| .emoji-picker-dropdown__menu {
 | |
|   position: relative;
 | |
|   margin-top: 5px;
 | |
|   z-index: 2;
 | |
|   background: var(--dropdown-background-color);
 | |
|   backdrop-filter: var(--background-filter);
 | |
|   border: 1px solid var(--dropdown-border-color);
 | |
|   box-shadow: var(--dropdown-shadow);
 | |
|   border-radius: 5px;
 | |
| 
 | |
|   .emoji-mart-scroll {
 | |
|     transition: opacity 200ms ease;
 | |
|   }
 | |
| 
 | |
|   &.selecting .emoji-mart-scroll {
 | |
|     opacity: 0.5;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .emoji-picker-dropdown__modifiers {
 | |
|   position: absolute;
 | |
|   top: 60px;
 | |
|   inset-inline-end: 11px;
 | |
|   cursor: pointer;
 | |
| }
 | |
| 
 | |
| .emoji-picker-dropdown__modifiers__menu {
 | |
|   position: absolute;
 | |
|   z-index: 4;
 | |
|   top: -5px;
 | |
|   inset-inline-start: -9px;
 | |
|   background: var(--dropdown-background-color);
 | |
|   border: 1px solid var(--dropdown-border-color);
 | |
|   border-radius: 4px;
 | |
|   box-shadow: var(--dropdown-shadow);
 | |
|   overflow: hidden;
 | |
| 
 | |
|   button {
 | |
|     display: block;
 | |
|     cursor: pointer;
 | |
|     border: 0;
 | |
|     padding: 4px 8px;
 | |
|     background: transparent;
 | |
| 
 | |
|     &:hover,
 | |
|     &:focus,
 | |
|     &:active {
 | |
|       background: var(--dropdown-border-color);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .emoji-mart-emoji {
 | |
|     height: 22px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .emoji-mart-emoji {
 | |
|   span {
 | |
|     background-repeat: no-repeat;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .upload-area {
 | |
|   align-items: center;
 | |
|   background: rgba($base-overlay-background, 0.8);
 | |
|   display: flex;
 | |
|   height: 100vh;
 | |
|   justify-content: center;
 | |
|   inset-inline-start: 0;
 | |
|   opacity: 0;
 | |
|   position: fixed;
 | |
|   top: 0;
 | |
|   visibility: hidden;
 | |
|   width: 100vw;
 | |
|   z-index: 2000;
 | |
| 
 | |
|   * {
 | |
|     pointer-events: none;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .upload-area__drop {
 | |
|   width: 320px;
 | |
|   height: 160px;
 | |
|   display: flex;
 | |
|   box-sizing: border-box;
 | |
|   position: relative;
 | |
|   padding: 8px;
 | |
| }
 | |
| 
 | |
| .upload-area__background {
 | |
|   position: absolute;
 | |
|   top: 0;
 | |
|   inset-inline-end: 0;
 | |
|   bottom: 0;
 | |
|   inset-inline-start: 0;
 | |
|   z-index: -1;
 | |
|   border-radius: 4px;
 | |
|   background: $ui-base-color;
 | |
|   box-shadow: 0 0 5px rgba($base-shadow-color, 0.2);
 | |
| }
 | |
| 
 | |
| .upload-area__content {
 | |
|   flex: 1;
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   justify-content: center;
 | |
|   text-align: center;
 | |
|   color: $secondary-text-color;
 | |
|   font-size: 18px;
 | |
|   font-weight: 500;
 | |
|   border: 2px dashed $ui-base-lighter-color;
 | |
|   border-radius: 4px;
 | |
| }
 | |
| 
 | |
| .upload-progress {
 | |
|   color: $darker-text-color;
 | |
|   overflow: hidden;
 | |
|   display: flex;
 | |
|   gap: 8px;
 | |
|   align-items: center;
 | |
|   padding: 0 12px;
 | |
| 
 | |
|   .icon {
 | |
|     width: 24px;
 | |
|     height: 24px;
 | |
|     color: $ui-highlight-color;
 | |
|   }
 | |
| 
 | |
|   span {
 | |
|     font-size: 12px;
 | |
|     text-transform: uppercase;
 | |
|     font-weight: 500;
 | |
|     display: block;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .upload-progress__message {
 | |
|   flex: 1 1 auto;
 | |
| }
 | |
| 
 | |
| .upload-progress__backdrop {
 | |
|   width: 100%;
 | |
|   height: 6px;
 | |
|   border-radius: 6px;
 | |
|   background: var(--background-color);
 | |
|   position: relative;
 | |
|   margin-top: 5px;
 | |
| }
 | |
| 
 | |
| .upload-progress__tracker {
 | |
|   position: absolute;
 | |
|   inset-inline-start: 0;
 | |
|   top: 0;
 | |
|   height: 6px;
 | |
|   background: $ui-highlight-color;
 | |
|   border-radius: 6px;
 | |
| }
 | |
| 
 | |
| .emoji-button {
 | |
|   display: block;
 | |
|   padding-top: 5px;
 | |
|   padding-bottom: 2px;
 | |
|   padding-inline-start: 2px;
 | |
|   padding-inline-end: 5px;
 | |
|   outline: 0;
 | |
|   cursor: pointer;
 | |
| 
 | |
|   img {
 | |
|     filter: grayscale(100%);
 | |
|     opacity: 0.8;
 | |
|     display: block;
 | |
|     margin: 0;
 | |
|     width: 22px;
 | |
|     height: 22px;
 | |
|   }
 | |
| 
 | |
|   &:hover,
 | |
|   &:active,
 | |
|   &:focus {
 | |
|     img {
 | |
|       opacity: 1;
 | |
|       filter: none;
 | |
|       border-radius: 100%;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &:focus-visible {
 | |
|     img {
 | |
|       outline: $ui-button-icon-focus-outline;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .dropdown--active .emoji-button img {
 | |
|   opacity: 1;
 | |
|   filter: none;
 | |
| }
 | |
| 
 | |
| .privacy-dropdown__dropdown,
 | |
| .language-dropdown__dropdown {
 | |
|   box-shadow: var(--dropdown-shadow);
 | |
|   background: var(--dropdown-background-color);
 | |
|   backdrop-filter: var(--background-filter);
 | |
|   border: 1px solid var(--dropdown-border-color);
 | |
|   padding: 4px;
 | |
|   border-radius: 4px;
 | |
|   overflow: hidden;
 | |
|   z-index: 2;
 | |
|   width: 300px;
 | |
| 
 | |
|   &.top {
 | |
|     transform-origin: 50% 100%;
 | |
|   }
 | |
| 
 | |
|   &.bottom {
 | |
|     transform-origin: 50% 0;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .modal-root__container .privacy-dropdown {
 | |
|   flex-grow: 0;
 | |
| }
 | |
| 
 | |
| .modal-root__container .privacy-dropdown__dropdown {
 | |
|   pointer-events: auto;
 | |
|   z-index: 9999;
 | |
| }
 | |
| 
 | |
| .privacy-dropdown__option {
 | |
|   font-size: 14px;
 | |
|   line-height: 20px;
 | |
|   letter-spacing: 0.25px;
 | |
|   padding: 8px 12px;
 | |
|   cursor: pointer;
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   gap: 12px;
 | |
|   border-radius: 4px;
 | |
|   color: $primary-text-color;
 | |
| 
 | |
|   &:hover,
 | |
|   &:active {
 | |
|     background: var(--dropdown-border-color);
 | |
|   }
 | |
| 
 | |
|   &:focus,
 | |
|   &.active {
 | |
|     background: $ui-highlight-color;
 | |
|     color: $primary-text-color;
 | |
|     outline: 0;
 | |
| 
 | |
|     .privacy-dropdown__option__content,
 | |
|     .privacy-dropdown__option__content strong,
 | |
|     .privacy-dropdown__option__additional {
 | |
|       color: $primary-text-color;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__additional {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     justify-content: center;
 | |
|     color: $darker-text-color;
 | |
|     cursor: help;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .privacy-dropdown__option__icon {
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   justify-content: center;
 | |
| }
 | |
| 
 | |
| .privacy-dropdown__option__content {
 | |
|   flex: 1 1 auto;
 | |
|   color: $darker-text-color;
 | |
| 
 | |
|   strong {
 | |
|     color: $primary-text-color;
 | |
|     font-weight: 500;
 | |
|     display: block;
 | |
| 
 | |
|     @each $lang in $cjk-langs {
 | |
|       &:lang(#{$lang}) {
 | |
|         font-weight: 700;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .language-dropdown {
 | |
|   &__dropdown {
 | |
|     padding: 0;
 | |
| 
 | |
|     .emoji-mart-search {
 | |
|       padding: 10px;
 | |
|       background: var(--dropdown-background-color);
 | |
| 
 | |
|       input {
 | |
|         padding: 8px 12px;
 | |
|         background: $ui-base-color;
 | |
|         border: 1px solid var(--background-border-color);
 | |
|         color: $darker-text-color;
 | |
| 
 | |
|         @media screen and (width <= 600px) {
 | |
|           font-size: 16px;
 | |
|           line-height: 24px;
 | |
|           letter-spacing: 0.5px;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .emoji-mart-search-icon {
 | |
|       inset-inline-end: 15px;
 | |
|       opacity: 1;
 | |
|       color: $darker-text-color;
 | |
| 
 | |
|       .icon {
 | |
|         width: 18px;
 | |
|         height: 18px;
 | |
|       }
 | |
| 
 | |
|       &:disabled {
 | |
|         opacity: 0.38;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .emoji-mart-scroll {
 | |
|       padding: 0 10px 10px;
 | |
|       background: var(--dropdown-background-color);
 | |
|     }
 | |
| 
 | |
|     &__results {
 | |
|       &__item {
 | |
|         display: flex;
 | |
|         align-items: center;
 | |
|         gap: 0.5em;
 | |
|         cursor: pointer;
 | |
|         color: $primary-text-color;
 | |
|         font-size: 14px;
 | |
|         line-height: 20px;
 | |
|         letter-spacing: 0.25px;
 | |
|         font-weight: 500;
 | |
|         padding: 8px 12px;
 | |
|         border-radius: 4px;
 | |
|         overflow: hidden;
 | |
|         white-space: nowrap;
 | |
|         text-overflow: ellipsis;
 | |
| 
 | |
|         &__common-name {
 | |
|           color: $darker-text-color;
 | |
|           font-weight: 400;
 | |
|         }
 | |
| 
 | |
|         &:active,
 | |
|         &:hover {
 | |
|           background: var(--dropdown-border-color);
 | |
|         }
 | |
| 
 | |
|         &:focus,
 | |
|         &.active {
 | |
|           background: $ui-highlight-color;
 | |
|           color: $primary-text-color;
 | |
|           outline: 0;
 | |
| 
 | |
|           .language-dropdown__dropdown__results__item__common-name {
 | |
|             color: $primary-text-color;
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .search {
 | |
|   margin-bottom: 32px;
 | |
|   position: relative;
 | |
| 
 | |
|   .layout-multiple-columns & {
 | |
|     margin-bottom: 10px;
 | |
|   }
 | |
| 
 | |
|   &__popout {
 | |
|     box-sizing: border-box;
 | |
|     display: none;
 | |
|     position: absolute;
 | |
|     inset-inline-start: 0;
 | |
|     margin-top: -2px;
 | |
|     width: 100%;
 | |
|     background: var(--input-background-color);
 | |
|     border: 1px solid var(--background-border-color);
 | |
|     border-radius: 0 0 4px 4px;
 | |
|     box-shadow: var(--dropdown-shadow);
 | |
|     z-index: 99;
 | |
|     font-size: 13px;
 | |
|     padding: 15px 5px;
 | |
| 
 | |
|     h4 {
 | |
|       text-transform: uppercase;
 | |
|       color: $darker-text-color;
 | |
|       font-weight: 500;
 | |
|       padding: 0 10px;
 | |
|       margin-bottom: 10px;
 | |
|     }
 | |
| 
 | |
|     .icon-button {
 | |
|       padding: 0;
 | |
|       color: $darker-text-color;
 | |
|     }
 | |
| 
 | |
|     .icon {
 | |
|       width: 18px;
 | |
|       height: 18px;
 | |
|     }
 | |
| 
 | |
|     &__menu {
 | |
|       margin-bottom: 20px;
 | |
| 
 | |
|       &:last-child {
 | |
|         margin-bottom: 0;
 | |
|       }
 | |
| 
 | |
|       &__message {
 | |
|         color: $darker-text-color;
 | |
|         padding: 0 10px;
 | |
|       }
 | |
| 
 | |
|       &__item {
 | |
|         display: block;
 | |
|         box-sizing: border-box;
 | |
|         width: 100%;
 | |
|         border: 0;
 | |
|         font: inherit;
 | |
|         background: transparent;
 | |
|         color: $darker-text-color;
 | |
|         padding: 10px;
 | |
|         cursor: pointer;
 | |
|         border-radius: 4px;
 | |
|         text-align: start;
 | |
|         text-overflow: ellipsis;
 | |
|         overflow: hidden;
 | |
|         white-space: nowrap;
 | |
| 
 | |
|         &--flex {
 | |
|           display: flex;
 | |
|           justify-content: space-between;
 | |
|         }
 | |
| 
 | |
|         .icon-button {
 | |
|           transition: none;
 | |
|         }
 | |
| 
 | |
|         &:hover,
 | |
|         &:focus,
 | |
|         &:active,
 | |
|         &.selected {
 | |
|           background: $ui-highlight-color;
 | |
|           color: $primary-text-color;
 | |
| 
 | |
|           .icon-button {
 | |
|             color: $primary-text-color;
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         mark {
 | |
|           background: transparent;
 | |
|           font-weight: 700;
 | |
|           color: $primary-text-color;
 | |
|         }
 | |
| 
 | |
|         span {
 | |
|           overflow: inherit;
 | |
|           text-overflow: inherit;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.active {
 | |
|     .search__input {
 | |
|       border-radius: 4px 4px 0 0;
 | |
|     }
 | |
| 
 | |
|     .search__popout {
 | |
|       display: block;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .search__input {
 | |
|   @include search-input;
 | |
| 
 | |
|   display: block;
 | |
|   padding: 12px 16px;
 | |
|   padding-inline-start: 16px + 15px + 8px;
 | |
|   line-height: normal;
 | |
| 
 | |
|   &::-moz-focus-inner {
 | |
|     border: 0;
 | |
|   }
 | |
| 
 | |
|   &::-moz-focus-inner,
 | |
|   &:focus,
 | |
|   &:active {
 | |
|     outline: 0 !important;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .search__icon {
 | |
|   background: transparent;
 | |
|   border: 0;
 | |
|   padding: 0;
 | |
|   position: absolute;
 | |
|   top: 12px + 2px;
 | |
|   cursor: default;
 | |
|   pointer-events: none;
 | |
|   margin-inline-start: 16px - 2px;
 | |
|   width: 20px;
 | |
|   height: 20px;
 | |
| 
 | |
|   &::-moz-focus-inner {
 | |
|     border: 0;
 | |
|   }
 | |
| 
 | |
|   &::-moz-focus-inner,
 | |
|   &:focus {
 | |
|     outline: 0 !important;
 | |
|   }
 | |
| 
 | |
|   .icon {
 | |
|     position: absolute;
 | |
|     top: 0;
 | |
|     inset-inline-start: 0;
 | |
|     opacity: 0;
 | |
|     transition: all 100ms linear;
 | |
|     transition-property: transform, opacity;
 | |
|     width: 20px;
 | |
|     height: 20px;
 | |
|     color: $darker-text-color;
 | |
| 
 | |
|     &.active {
 | |
|       pointer-events: auto;
 | |
|       opacity: 1;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .icon-search {
 | |
|     transform: rotate(90deg);
 | |
| 
 | |
|     &.active {
 | |
|       pointer-events: none;
 | |
|       transform: rotate(0deg);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .icon-times-circle {
 | |
|     transform: rotate(0deg);
 | |
|     cursor: pointer;
 | |
| 
 | |
|     &.active {
 | |
|       transform: rotate(90deg);
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .search-results__section {
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
| 
 | |
|   &:last-child {
 | |
|     border-bottom: 0;
 | |
|   }
 | |
| 
 | |
|   &__header {
 | |
|     border-bottom: 1px solid var(--background-border-color);
 | |
|     background: var(--surface-background-color);
 | |
|     padding: 15px;
 | |
|     font-weight: 500;
 | |
|     font-size: 14px;
 | |
|     color: $darker-text-color;
 | |
|     display: flex;
 | |
|     justify-content: space-between;
 | |
| 
 | |
|     h3 {
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       gap: 5px;
 | |
|     }
 | |
| 
 | |
|     button {
 | |
|       color: $highlight-text-color;
 | |
|       padding: 0;
 | |
|       border: 0;
 | |
|       background: 0;
 | |
|       font: inherit;
 | |
| 
 | |
|       &:hover,
 | |
|       &:active,
 | |
|       &:focus {
 | |
|         text-decoration: underline;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .account:last-child,
 | |
|   & > div:last-child .status {
 | |
|     border-bottom: 0;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .search-results__info {
 | |
|   padding: 20px;
 | |
|   color: $darker-text-color;
 | |
|   text-align: center;
 | |
| }
 | |
| 
 | |
| .modal-root {
 | |
|   position: relative;
 | |
|   z-index: 9998;
 | |
| }
 | |
| 
 | |
| .modal-root__overlay {
 | |
|   position: fixed;
 | |
|   top: 0;
 | |
|   inset-inline-start: 0;
 | |
|   inset-inline-end: 0;
 | |
|   bottom: 0;
 | |
|   opacity: 0.9;
 | |
|   background: $base-overlay-background;
 | |
|   transition: background 0.5s;
 | |
| }
 | |
| 
 | |
| .modal-root__container {
 | |
|   position: fixed;
 | |
|   top: 0;
 | |
|   inset-inline-start: 0;
 | |
|   width: 100%;
 | |
|   height: 100%;
 | |
|   max-width: 100vw;
 | |
|   max-height: 100vh;
 | |
|   box-sizing: border-box;
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
|   align-items: center;
 | |
|   justify-content: center;
 | |
|   align-content: space-around;
 | |
|   z-index: 9999;
 | |
|   pointer-events: none;
 | |
|   user-select: none;
 | |
|   overscroll-behavior: none;
 | |
| }
 | |
| 
 | |
| .modal-root__modal {
 | |
|   pointer-events: auto;
 | |
|   user-select: text;
 | |
|   display: flex;
 | |
|   max-width: 100vw;
 | |
| 
 | |
|   @media screen and (width <= $mobile-breakpoint) {
 | |
|     margin-top: auto;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .video-modal .video-player {
 | |
|   max-height: 80vh;
 | |
|   max-width: 100vw;
 | |
| }
 | |
| 
 | |
| .audio-modal__container {
 | |
|   width: 50vw;
 | |
| }
 | |
| 
 | |
| .media-modal {
 | |
|   width: 100%;
 | |
|   height: 100%;
 | |
|   position: relative;
 | |
| 
 | |
|   &__buttons {
 | |
|     position: absolute;
 | |
|     inset-inline-end: 8px;
 | |
|     top: 8px;
 | |
|     z-index: 100;
 | |
|     display: flex;
 | |
|     gap: 8px;
 | |
|     align-items: center;
 | |
| 
 | |
|     .icon-button {
 | |
|       color: rgba($white, 0.7);
 | |
|       padding: 8px;
 | |
| 
 | |
|       .icon {
 | |
|         width: 24px;
 | |
|         height: 24px;
 | |
|         filter: var(--overlay-icon-shadow);
 | |
|       }
 | |
| 
 | |
|       &:hover,
 | |
|       &:focus,
 | |
|       &:active {
 | |
|         color: $white;
 | |
|         background-color: rgba($white, 0.15);
 | |
|       }
 | |
| 
 | |
|       &:focus {
 | |
|         background-color: rgba($white, 0.3);
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .media-modal__closer {
 | |
|   position: absolute;
 | |
|   top: 0;
 | |
|   inset-inline-start: 0;
 | |
|   inset-inline-end: 0;
 | |
|   bottom: 0;
 | |
| }
 | |
| 
 | |
| .media-modal__navigation {
 | |
|   position: absolute;
 | |
|   top: 0;
 | |
|   inset-inline-start: 0;
 | |
|   inset-inline-end: 0;
 | |
|   bottom: 0;
 | |
|   pointer-events: none;
 | |
|   transition: opacity 0.3s linear;
 | |
|   will-change: opacity;
 | |
| 
 | |
|   * {
 | |
|     pointer-events: auto;
 | |
|   }
 | |
| 
 | |
|   &.media-modal__navigation--hidden {
 | |
|     opacity: 0;
 | |
| 
 | |
|     * {
 | |
|       pointer-events: none;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .media-modal__nav {
 | |
|   background: transparent;
 | |
|   box-sizing: border-box;
 | |
|   border: 0;
 | |
|   color: rgba($white, 0.7);
 | |
|   cursor: pointer;
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   font-size: 24px;
 | |
|   height: 20vmax;
 | |
|   margin: auto 0;
 | |
|   padding: 30px 15px;
 | |
|   position: absolute;
 | |
|   top: 0;
 | |
|   bottom: 0;
 | |
| 
 | |
|   &:hover,
 | |
|   &:focus,
 | |
|   &:active {
 | |
|     color: $white;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .media-modal__nav--left {
 | |
|   inset-inline-start: 0;
 | |
| }
 | |
| 
 | |
| .media-modal__nav--right {
 | |
|   inset-inline-end: 0;
 | |
| }
 | |
| 
 | |
| .media-modal__overlay {
 | |
|   max-width: 600px;
 | |
|   position: absolute;
 | |
|   inset-inline-start: 0;
 | |
|   inset-inline-end: 0;
 | |
|   bottom: 0;
 | |
|   margin: 0 auto;
 | |
| 
 | |
|   .picture-in-picture__footer {
 | |
|     border-radius: 0;
 | |
|     border: none;
 | |
|     background: transparent;
 | |
|     backdrop-filter: none;
 | |
|     padding: 16px;
 | |
| 
 | |
|     .icon-button {
 | |
|       color: $white;
 | |
| 
 | |
|       .icon {
 | |
|         filter: var(--overlay-icon-shadow);
 | |
|       }
 | |
| 
 | |
|       &:hover,
 | |
|       &:focus,
 | |
|       &:active {
 | |
|         color: $white;
 | |
|         background-color: rgba($white, 0.15);
 | |
|       }
 | |
| 
 | |
|       &:focus {
 | |
|         background-color: rgba($white, 0.3);
 | |
|       }
 | |
| 
 | |
|       &.active {
 | |
|         color: $highlight-text-color;
 | |
| 
 | |
|         &:hover,
 | |
|         &:focus,
 | |
|         &:active {
 | |
|           background: rgba($highlight-text-color, 0.15);
 | |
|         }
 | |
| 
 | |
|         &:focus {
 | |
|           background: rgba($highlight-text-color, 0.3);
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       &.star-icon.active {
 | |
|         color: $gold-star;
 | |
| 
 | |
|         &:hover,
 | |
|         &:focus,
 | |
|         &:active {
 | |
|           background: rgba($gold-star, 0.15);
 | |
|         }
 | |
| 
 | |
|         &:focus {
 | |
|           background: rgba($gold-star, 0.3);
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       &.disabled {
 | |
|         color: $white;
 | |
|         background-color: transparent;
 | |
|         cursor: default;
 | |
|         opacity: 0.4;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .media-modal__pagination {
 | |
|   display: flex;
 | |
|   justify-content: center;
 | |
|   margin-bottom: 20px;
 | |
| }
 | |
| 
 | |
| .media-modal__page-dot {
 | |
|   flex: 0 0 auto;
 | |
|   background-color: $white;
 | |
|   filter: var(--overlay-icon-shadow);
 | |
|   opacity: 0.4;
 | |
|   height: 6px;
 | |
|   width: 6px;
 | |
|   border-radius: 50%;
 | |
|   margin: 0 4px;
 | |
|   padding: 0;
 | |
|   border: 0;
 | |
|   font-size: 0;
 | |
|   transition: opacity 0.2s ease-in-out;
 | |
| 
 | |
|   &.active {
 | |
|     opacity: 1;
 | |
|   }
 | |
| 
 | |
|   &:focus {
 | |
|     outline: 0;
 | |
|     background-color: $highlight-text-color;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .modal-placeholder {
 | |
|   width: 588px;
 | |
|   min-height: 478px;
 | |
|   flex-direction: column;
 | |
|   background: var(--modal-background-color);
 | |
|   backdrop-filter: var(--background-filter);
 | |
|   border: 1px solid var(--modal-border-color);
 | |
|   border-radius: 16px;
 | |
| 
 | |
|   &__error {
 | |
|     padding: 24px;
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     flex-direction: column;
 | |
| 
 | |
|     &__image {
 | |
|       width: 70%;
 | |
|       max-width: 350px;
 | |
|     }
 | |
| 
 | |
|     &__message {
 | |
|       text-align: center;
 | |
|       text-wrap: balance;
 | |
|       font-size: 14px;
 | |
|       line-height: 20px;
 | |
|       letter-spacing: 0.25px;
 | |
| 
 | |
|       &__actions {
 | |
|         margin-top: 24px;
 | |
|         display: flex;
 | |
|         gap: 10px;
 | |
|         align-items: center;
 | |
|         justify-content: center;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .safety-action-modal {
 | |
|   width: 600px;
 | |
|   flex-direction: column;
 | |
| 
 | |
|   &__top,
 | |
|   &__bottom {
 | |
|     display: flex;
 | |
|     gap: 8px;
 | |
|     padding: 24px;
 | |
|     flex-direction: column;
 | |
|     background: var(--modal-background-color);
 | |
|     backdrop-filter: var(--background-filter);
 | |
|     border: 1px solid var(--modal-border-color);
 | |
|   }
 | |
| 
 | |
|   &__top {
 | |
|     border-radius: 16px 16px 0 0;
 | |
|     border-bottom: 0;
 | |
|     gap: 16px;
 | |
|   }
 | |
| 
 | |
|   &__bottom {
 | |
|     border-radius: 0 0 16px 16px;
 | |
|     border-top: 0;
 | |
| 
 | |
|     @media screen and (max-width: $mobile-breakpoint) {
 | |
|       border-radius: 0;
 | |
|       border-bottom: 0;
 | |
|       padding-bottom: 32px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__header {
 | |
|     display: flex;
 | |
|     gap: 16px;
 | |
|     align-items: center;
 | |
|     font-size: 14px;
 | |
|     line-height: 20px;
 | |
|     color: $darker-text-color;
 | |
| 
 | |
|     &__icon {
 | |
|       border-radius: 64px;
 | |
|       background: $ui-highlight-color;
 | |
|       color: $white;
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       justify-content: center;
 | |
|       width: 40px;
 | |
|       height: 40px;
 | |
|       flex-shrink: 0;
 | |
| 
 | |
|       .icon {
 | |
|         width: 24px;
 | |
|         height: 24px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     h1 {
 | |
|       font-size: 22px;
 | |
|       line-height: 28px;
 | |
|       color: $primary-text-color;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__confirmation {
 | |
|     font-size: 14px;
 | |
|     line-height: 20px;
 | |
|     color: $darker-text-color;
 | |
| 
 | |
|     h1 {
 | |
|       font-size: 16px;
 | |
|       line-height: 24px;
 | |
|       color: $primary-text-color;
 | |
|       font-weight: 500;
 | |
|       margin-bottom: 8px;
 | |
|     }
 | |
| 
 | |
|     strong {
 | |
|       font-weight: 700;
 | |
|       color: $primary-text-color;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__status {
 | |
|     border: 1px solid var(--modal-border-color);
 | |
|     border-radius: 8px;
 | |
|     padding: 8px;
 | |
|     cursor: pointer;
 | |
| 
 | |
|     &__account {
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       gap: 4px;
 | |
|       margin-bottom: 8px;
 | |
|       color: $dark-text-color;
 | |
| 
 | |
|       bdi {
 | |
|         color: inherit;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &__content {
 | |
|       display: -webkit-box;
 | |
|       font-size: 15px;
 | |
|       line-height: 22px;
 | |
|       color: $dark-text-color;
 | |
|       -webkit-line-clamp: 4;
 | |
|       -webkit-box-orient: vertical;
 | |
|       max-height: 4 * 22px;
 | |
|       overflow: hidden;
 | |
| 
 | |
|       p,
 | |
|       a {
 | |
|         color: inherit;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .reply-indicator__attachments {
 | |
|       margin-top: 0;
 | |
|       font-size: 15px;
 | |
|       line-height: 22px;
 | |
|       color: $dark-text-color;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__bullet-points {
 | |
|     display: flex;
 | |
|     flex-direction: column;
 | |
|     gap: 8px;
 | |
|     font-size: 16px;
 | |
|     line-height: 24px;
 | |
| 
 | |
|     & > div {
 | |
|       display: flex;
 | |
|       gap: 16px;
 | |
|       align-items: center;
 | |
| 
 | |
|       strong {
 | |
|         font-weight: 700;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &--deemphasized {
 | |
|       color: $secondary-text-color;
 | |
|     }
 | |
| 
 | |
|     &__icon {
 | |
|       width: 40px;
 | |
|       height: 40px;
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       justify-content: center;
 | |
|       flex-shrink: 0;
 | |
| 
 | |
|       .icon {
 | |
|         width: 24px;
 | |
|         height: 24px;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__field-group {
 | |
|     display: flex;
 | |
|     flex-direction: column;
 | |
| 
 | |
|     label {
 | |
|       display: flex;
 | |
|       gap: 16px;
 | |
|       align-items: center;
 | |
|       font-size: 16px;
 | |
|       line-height: 24px;
 | |
|       height: 32px;
 | |
|       padding: 0 12px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__caveats {
 | |
|     font-size: 14px;
 | |
|     padding: 0 12px;
 | |
| 
 | |
|     strong {
 | |
|       font-weight: 500;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__bottom {
 | |
|     padding-top: 0;
 | |
| 
 | |
|     &__collapsible {
 | |
|       display: none;
 | |
|       flex-direction: column;
 | |
|       gap: 16px;
 | |
|     }
 | |
| 
 | |
|     &.active {
 | |
|       background: var(--modal-background-variant-color);
 | |
|       padding-top: 24px;
 | |
| 
 | |
|       .safety-action-modal__bottom__collapsible {
 | |
|         display: flex;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__actions {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     gap: 8px;
 | |
|     justify-content: flex-end;
 | |
| 
 | |
|     &__hint {
 | |
|       font-size: 14px;
 | |
|       line-height: 20px;
 | |
|       color: $dark-text-color;
 | |
|     }
 | |
| 
 | |
|     .link-button {
 | |
|       padding: 10px 12px;
 | |
|       font-weight: 600;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .dialog-modal {
 | |
|   width: 588px;
 | |
|   max-height: 80vh;
 | |
|   flex-direction: column;
 | |
|   background: var(--modal-background-color);
 | |
|   backdrop-filter: var(--background-filter);
 | |
|   border: 1px solid var(--modal-border-color);
 | |
|   border-radius: 16px;
 | |
| 
 | |
|   &__header {
 | |
|     box-sizing: border-box;
 | |
|     border-bottom: 1px solid var(--modal-border-color);
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     justify-content: space-between;
 | |
|     flex-direction: row-reverse;
 | |
|     padding: 12px 24px;
 | |
|     min-height: 61px;
 | |
| 
 | |
|     &__title {
 | |
|       font-size: 16px;
 | |
|       line-height: 24px;
 | |
|       font-weight: 500;
 | |
|       letter-spacing: 0.15px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__content {
 | |
|     font-size: 14px;
 | |
|     line-height: 20px;
 | |
|     letter-spacing: 0.25px;
 | |
|     overflow-y: auto;
 | |
| 
 | |
|     &__form {
 | |
|       display: flex;
 | |
|       flex-direction: column;
 | |
|       gap: 16px;
 | |
|       padding: 24px;
 | |
|     }
 | |
| 
 | |
|     &__preview {
 | |
|       display: flex;
 | |
|       flex-direction: column;
 | |
|       gap: 16px;
 | |
|       align-items: center;
 | |
|       justify-content: center;
 | |
|       padding: 24px;
 | |
|       background: #000;
 | |
| 
 | |
|       img {
 | |
|         display: block;
 | |
|       }
 | |
| 
 | |
|       img,
 | |
|       .gifv video {
 | |
|         outline: 1px solid var(--media-outline-color);
 | |
|         outline-offset: -1px;
 | |
|         border-radius: 8px;
 | |
|       }
 | |
| 
 | |
|       img,
 | |
|       .gifv video,
 | |
|       .video-player,
 | |
|       .audio-player {
 | |
|         max-width: 360px;
 | |
|         max-height: 45vh;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__popout {
 | |
|     background: var(--dropdown-background-color);
 | |
|     backdrop-filter: var(--background-filter);
 | |
|     border: 1px solid var(--dropdown-border-color);
 | |
|     box-shadow: var(--dropdown-shadow);
 | |
|     max-width: 320px;
 | |
|     padding: 16px;
 | |
|     border-radius: 8px;
 | |
|     z-index: 9999 !important;
 | |
|     font-size: 14px;
 | |
|     line-height: 20px;
 | |
|     color: $darker-text-color;
 | |
|   }
 | |
| 
 | |
|   .copy-paste-text {
 | |
|     margin-bottom: 0;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .hotkey-combination {
 | |
|   display: inline-flex;
 | |
|   align-items: center;
 | |
|   gap: 4px;
 | |
| 
 | |
|   kbd {
 | |
|     padding: 3px 5px;
 | |
|     border: 1px solid var(--background-border-color);
 | |
|     border-radius: 4px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .boost-modal,
 | |
| .report-modal,
 | |
| .actions-modal,
 | |
| .compare-history-modal {
 | |
|   background: var(--background-color);
 | |
|   color: $primary-text-color;
 | |
|   border-radius: 4px;
 | |
|   border: 1px solid var(--background-border-color);
 | |
|   overflow: hidden;
 | |
|   max-width: 90vw;
 | |
|   width: 480px;
 | |
|   position: relative;
 | |
|   flex-direction: column;
 | |
| 
 | |
|   @media screen and (max-width: $no-columns-breakpoint) {
 | |
|     border-bottom: 0;
 | |
|     border-radius: 4px 4px 0 0;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .boost-modal__container {
 | |
|   overflow-y: auto;
 | |
|   padding: 10px;
 | |
| 
 | |
|   .status {
 | |
|     user-select: text;
 | |
|     border-bottom: 0;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .boost-modal__action-bar {
 | |
|   display: flex;
 | |
|   justify-content: space-between;
 | |
|   align-items: center;
 | |
|   background: $ui-secondary-color;
 | |
|   padding: 15px;
 | |
| 
 | |
|   & > div {
 | |
|     flex: 1 1 auto;
 | |
|     text-align: end;
 | |
|     color: $lighter-text-color;
 | |
|     padding-inline-end: 10px;
 | |
|   }
 | |
| 
 | |
|   .icon {
 | |
|     vertical-align: middle;
 | |
|   }
 | |
| 
 | |
|   .button {
 | |
|     flex: 0 0 auto;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .report-modal {
 | |
|   width: 90vw;
 | |
|   max-width: 700px;
 | |
|   border: 1px solid var(--background-border-color);
 | |
| }
 | |
| 
 | |
| .report-dialog-modal {
 | |
|   max-width: 90vw;
 | |
|   width: 480px;
 | |
|   height: 80vh;
 | |
|   background: var(--background-color);
 | |
|   color: $primary-text-color;
 | |
|   border-radius: 4px;
 | |
|   border: 1px solid var(--background-border-color);
 | |
|   overflow: hidden;
 | |
|   position: relative;
 | |
|   flex-direction: column;
 | |
|   display: flex;
 | |
| 
 | |
|   &__container {
 | |
|     box-sizing: border-box;
 | |
|     border-top: 1px solid var(--background-border-color);
 | |
|     padding: 20px;
 | |
|     flex-grow: 1;
 | |
|     display: flex;
 | |
|     flex-direction: column;
 | |
|     min-height: 0;
 | |
|     overflow: auto;
 | |
|   }
 | |
| 
 | |
|   &__title {
 | |
|     font-size: 28px;
 | |
|     line-height: 33px;
 | |
|     font-weight: 700;
 | |
|     margin-bottom: 15px;
 | |
| 
 | |
|     @media screen and (height <= 800px) {
 | |
|       font-size: 22px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__subtitle {
 | |
|     font-size: 17px;
 | |
|     font-weight: 600;
 | |
|     line-height: 22px;
 | |
|     margin-bottom: 4px;
 | |
|   }
 | |
| 
 | |
|   &__lead {
 | |
|     font-size: 17px;
 | |
|     line-height: 22px;
 | |
|     color: $secondary-text-color;
 | |
|     margin-bottom: 30px;
 | |
| 
 | |
|     a {
 | |
|       text-decoration: none;
 | |
|       color: $highlight-text-color;
 | |
|       font-weight: 500;
 | |
| 
 | |
|       &:hover {
 | |
|         text-decoration: underline;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__actions {
 | |
|     margin-top: 30px;
 | |
|     display: flex;
 | |
| 
 | |
|     .button {
 | |
|       flex: 1 1 auto;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__statuses {
 | |
|     flex-grow: 1;
 | |
|     min-height: 0;
 | |
|     overflow: auto;
 | |
|   }
 | |
| 
 | |
|   .status__content a {
 | |
|     color: $highlight-text-color;
 | |
|   }
 | |
| 
 | |
|   .status__content,
 | |
|   .status__content p {
 | |
|     color: $primary-text-color;
 | |
|   }
 | |
| 
 | |
|   .dialog-option {
 | |
|     align-items: center;
 | |
|     gap: 12px;
 | |
|   }
 | |
| 
 | |
|   .dialog-option .poll__input {
 | |
|     border-color: $darker-text-color;
 | |
|     color: $ui-secondary-color;
 | |
|     display: inline-flex;
 | |
|     align-items: center;
 | |
|     justify-content: center;
 | |
| 
 | |
|     svg {
 | |
|       width: 15px;
 | |
|       height: 15px;
 | |
|     }
 | |
| 
 | |
|     &:active,
 | |
|     &:focus,
 | |
|     &:hover {
 | |
|       border-color: $valid-value-color;
 | |
|       border-width: 4px;
 | |
|     }
 | |
| 
 | |
|     &.active {
 | |
|       border-color: $valid-value-color;
 | |
|       background: $valid-value-color;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .poll__option.dialog-option {
 | |
|     padding: 15px 0;
 | |
|     flex: 0 0 auto;
 | |
|     border-bottom: 1px solid var(--background-border-color);
 | |
| 
 | |
|     &:last-child {
 | |
|       border-bottom: 0;
 | |
|     }
 | |
| 
 | |
|     & > .poll__option__text {
 | |
|       font-size: 13px;
 | |
|       color: $secondary-text-color;
 | |
| 
 | |
|       strong {
 | |
|         font-size: 17px;
 | |
|         font-weight: 500;
 | |
|         line-height: 22px;
 | |
|         color: $primary-text-color;
 | |
|         display: block;
 | |
|         margin-bottom: 4px;
 | |
| 
 | |
|         &:last-child {
 | |
|           margin-bottom: 0;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .flex-spacer {
 | |
|     background: transparent;
 | |
|   }
 | |
| 
 | |
|   &__textarea {
 | |
|     display: block;
 | |
|     box-sizing: border-box;
 | |
|     width: 100%;
 | |
|     color: $primary-text-color;
 | |
|     background: $ui-base-color;
 | |
|     padding: 10px;
 | |
|     font-family: inherit;
 | |
|     font-size: 17px;
 | |
|     line-height: 22px;
 | |
|     resize: vertical;
 | |
|     border: 0;
 | |
|     border: 1px solid var(--background-border-color);
 | |
|     outline: 0;
 | |
|     border-radius: 4px;
 | |
|     margin: 20px 0;
 | |
| 
 | |
|     &:focus {
 | |
|       outline: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__toggle {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     margin-bottom: 16px;
 | |
|     gap: 8px;
 | |
| 
 | |
|     & > span {
 | |
|       display: block;
 | |
|       font-size: 14px;
 | |
|       font-weight: 500;
 | |
|       line-height: 20px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .button.button-secondary {
 | |
|     border-color: $ui-button-destructive-background-color;
 | |
|     color: $ui-button-destructive-background-color;
 | |
|     flex: 0 0 auto;
 | |
| 
 | |
|     &:hover,
 | |
|     &:focus,
 | |
|     &:active {
 | |
|       background: $ui-button-destructive-background-color;
 | |
|       border-color: $ui-button-destructive-background-color;
 | |
|       color: $white;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   hr {
 | |
|     border: 0;
 | |
|     background: transparent;
 | |
|     margin: 15px 0;
 | |
|   }
 | |
| 
 | |
|   .emoji-mart-search {
 | |
|     padding-inline-end: 10px;
 | |
|   }
 | |
| 
 | |
|   .emoji-mart-search-icon {
 | |
|     inset-inline-end: 10px + 5px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .report-modal__container {
 | |
|   display: flex;
 | |
|   border-top: 1px solid var(--background-border-color);
 | |
| 
 | |
|   @media screen and (width <= 480px) {
 | |
|     flex-wrap: wrap;
 | |
|     overflow-y: auto;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .report-modal__statuses,
 | |
| .report-modal__comment {
 | |
|   box-sizing: border-box;
 | |
|   width: 50%;
 | |
|   min-width: 50%;
 | |
| 
 | |
|   @media screen and (width <= 480px) {
 | |
|     width: 100%;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .report-modal__statuses,
 | |
| .focal-point-modal__content {
 | |
|   flex: 1 1 auto;
 | |
|   min-height: 20vh;
 | |
|   max-height: 80vh;
 | |
|   overflow-y: auto;
 | |
|   overflow-x: hidden;
 | |
| 
 | |
|   .status__content a {
 | |
|     color: $highlight-text-color;
 | |
|   }
 | |
| 
 | |
|   .status__content,
 | |
|   .status__content p {
 | |
|     color: $inverted-text-color;
 | |
|   }
 | |
| 
 | |
|   @media screen and (width <= 480px) {
 | |
|     max-height: 10vh;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .focal-point-modal__content {
 | |
|   @media screen and (width <= 480px) {
 | |
|     max-height: 40vh;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .setting-divider {
 | |
|   background: transparent;
 | |
|   border: 0;
 | |
|   margin: 0;
 | |
|   width: 100%;
 | |
|   height: 1px;
 | |
|   margin-bottom: 29px;
 | |
| }
 | |
| 
 | |
| .actions-modal {
 | |
|   border-radius: 8px 8px 0 0;
 | |
|   background: var(--dropdown-background-color);
 | |
|   backdrop-filter: var(--background-filter);
 | |
|   border-color: var(--dropdown-border-color);
 | |
|   box-shadow: var(--dropdown-shadow);
 | |
|   max-height: 80vh;
 | |
|   max-width: 80vw;
 | |
| 
 | |
|   ul {
 | |
|     overflow-y: auto;
 | |
|     padding-bottom: 8px;
 | |
|   }
 | |
| 
 | |
|   a,
 | |
|   button {
 | |
|     color: inherit;
 | |
|     display: flex;
 | |
|     padding: 16px;
 | |
|     font-size: 15px;
 | |
|     line-height: 21px;
 | |
|     background: transparent;
 | |
|     border: none;
 | |
|     align-items: center;
 | |
|     text-decoration: none;
 | |
|     width: 100%;
 | |
|     box-sizing: border-box;
 | |
| 
 | |
|     &:hover,
 | |
|     &:active,
 | |
|     &:focus {
 | |
|       background: var(--dropdown-border-color);
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .report-modal__target {
 | |
|   padding: 30px;
 | |
|   font-size: 16px;
 | |
| 
 | |
|   strong {
 | |
|     font-weight: 500;
 | |
| 
 | |
|     @each $lang in $cjk-langs {
 | |
|       &:lang(#{$lang}) {
 | |
|         font-weight: 700;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .report-modal__target {
 | |
|   text-align: center;
 | |
| }
 | |
| 
 | |
| .report-modal__target {
 | |
|   padding: 15px;
 | |
| 
 | |
|   .report-modal__close {
 | |
|     position: absolute;
 | |
|     top: 10px;
 | |
|     inset-inline-end: 10px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .compare-history-modal {
 | |
|   .report-modal__target {
 | |
|     border-bottom: 1px solid var(--background-border-color);
 | |
|   }
 | |
| 
 | |
|   &__container {
 | |
|     padding: 30px;
 | |
|     pointer-events: all;
 | |
|     overflow-y: auto;
 | |
|   }
 | |
| 
 | |
|   .status__content {
 | |
|     color: $secondary-text-color;
 | |
|     font-size: 19px;
 | |
|     line-height: 24px;
 | |
| 
 | |
|     .emojione {
 | |
|       width: 24px;
 | |
|       height: 24px;
 | |
|       margin: -1px 0 0;
 | |
|     }
 | |
| 
 | |
|     a {
 | |
|       color: $highlight-text-color;
 | |
|     }
 | |
| 
 | |
|     hr {
 | |
|       height: 0.25rem;
 | |
|       padding: 0;
 | |
|       background-color: $ui-secondary-color;
 | |
|       border: 0;
 | |
|       margin: 20px 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .media-gallery,
 | |
|   .audio-player,
 | |
|   .video-player {
 | |
|     margin-top: 15px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .loading-bar {
 | |
|   background-color: $highlight-text-color;
 | |
|   height: 3px;
 | |
|   position: fixed;
 | |
|   top: 0;
 | |
|   inset-inline-start: 0;
 | |
|   z-index: 9999;
 | |
| }
 | |
| 
 | |
| .media-gallery__actions {
 | |
|   position: absolute;
 | |
|   top: 6px;
 | |
|   inset-inline-end: 6px;
 | |
|   display: flex;
 | |
|   gap: 2px;
 | |
|   z-index: 2;
 | |
| 
 | |
|   &__pill {
 | |
|     display: block;
 | |
|     color: $white;
 | |
|     border: 0;
 | |
|     background: rgba($black, 0.65);
 | |
|     backdrop-filter: blur(10px) saturate(180%) contrast(75%) brightness(70%);
 | |
|     padding: 3px 12px;
 | |
|     border-radius: 99px;
 | |
|     font-size: 14px;
 | |
|     font-weight: 700;
 | |
|     line-height: 20px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .media-gallery__item__badges {
 | |
|   position: absolute;
 | |
|   bottom: 8px;
 | |
|   inset-inline-end: 8px;
 | |
|   display: flex;
 | |
|   gap: 2px;
 | |
|   pointer-events: none;
 | |
| }
 | |
| 
 | |
| .media-gallery__alt__label,
 | |
| .relationship-tag {
 | |
|   display: block;
 | |
|   text-align: center;
 | |
|   color: $white;
 | |
|   border: 0;
 | |
|   background: rgba($black, 0.65);
 | |
|   backdrop-filter: blur(10px) saturate(180%) contrast(75%) brightness(70%);
 | |
|   padding: 3px 8px;
 | |
|   border-radius: 4px;
 | |
|   font-size: 12px;
 | |
|   font-weight: 700;
 | |
|   z-index: 1;
 | |
|   line-height: 20px;
 | |
|   cursor: pointer;
 | |
|   pointer-events: auto;
 | |
| 
 | |
|   &--non-interactive {
 | |
|     pointer-events: none;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .relationship-tag {
 | |
|   text-transform: uppercase;
 | |
|   cursor: default;
 | |
| }
 | |
| 
 | |
| .media-gallery__alt__popover {
 | |
|   background: rgba($black, 0.65);
 | |
|   backdrop-filter: blur(10px) saturate(180%) contrast(75%) brightness(70%);
 | |
|   border-radius: 4px;
 | |
|   box-shadow: var(--dropdown-shadow);
 | |
|   padding: 16px;
 | |
|   min-width: 16em;
 | |
|   min-height: 2em;
 | |
|   max-width: 22em;
 | |
|   max-height: 30em;
 | |
|   overflow-y: auto;
 | |
| 
 | |
|   h4 {
 | |
|     font-size: 15px;
 | |
|     line-height: 20px;
 | |
|     font-weight: 500;
 | |
|     color: $white;
 | |
|     margin-bottom: 8px;
 | |
|   }
 | |
| 
 | |
|   p {
 | |
|     font-size: 15px;
 | |
|     line-height: 20px;
 | |
|     color: rgba($white, 0.85);
 | |
|     white-space: pre-line;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .attachment-list {
 | |
|   display: flex;
 | |
|   font-size: 14px;
 | |
|   border: 1px solid var(--background-border-color);
 | |
|   border-radius: 4px;
 | |
|   margin-top: 16px;
 | |
|   overflow: hidden;
 | |
| 
 | |
|   &__icon {
 | |
|     flex: 0 0 auto;
 | |
|     color: $dark-text-color;
 | |
|     padding: 8px 18px;
 | |
|     cursor: default;
 | |
|     border-inline-end: 1px solid var(--background-border-color);
 | |
|     display: flex;
 | |
|     flex-direction: column;
 | |
|     align-items: center;
 | |
|     justify-content: center;
 | |
|     font-size: 26px;
 | |
|   }
 | |
| 
 | |
|   &__list {
 | |
|     list-style: none;
 | |
|     padding: 4px 0;
 | |
|     padding-inline-start: 8px;
 | |
|     display: flex;
 | |
|     flex-direction: column;
 | |
|     justify-content: center;
 | |
| 
 | |
|     li {
 | |
|       display: block;
 | |
|       padding: 4px 0;
 | |
|     }
 | |
| 
 | |
|     a {
 | |
|       text-decoration: none;
 | |
|       color: $dark-text-color;
 | |
|       font-weight: 500;
 | |
| 
 | |
|       &:hover {
 | |
|         text-decoration: underline;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.compact {
 | |
|     border: 0;
 | |
| 
 | |
|     .attachment-list__list {
 | |
|       padding: 0;
 | |
|       display: block;
 | |
|     }
 | |
| 
 | |
|     .icon {
 | |
|       color: $dark-text-color;
 | |
|       vertical-align: middle;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| /* Media Gallery */
 | |
| .media-gallery {
 | |
|   box-sizing: border-box;
 | |
|   margin-top: 8px;
 | |
|   overflow: hidden;
 | |
|   border-radius: 8px;
 | |
|   position: relative;
 | |
|   width: 100%;
 | |
|   min-height: 64px;
 | |
|   display: grid;
 | |
|   grid-template-columns: 1fr 1fr;
 | |
|   grid-template-rows: 1fr 1fr;
 | |
|   gap: 2px;
 | |
| 
 | |
|   &--layout-2 {
 | |
|     & > .media-gallery__item:nth-child(1) {
 | |
|       border-end-end-radius: 0;
 | |
|       border-start-end-radius: 0;
 | |
|     }
 | |
| 
 | |
|     & > .media-gallery__item:nth-child(2) {
 | |
|       border-start-start-radius: 0;
 | |
|       border-end-start-radius: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &--layout-3 {
 | |
|     min-height: calc(64px * 2 + 8px);
 | |
| 
 | |
|     & > .media-gallery__item:nth-child(1) {
 | |
|       border-end-end-radius: 0;
 | |
|       border-start-end-radius: 0;
 | |
|     }
 | |
| 
 | |
|     & > .media-gallery__item:nth-child(2) {
 | |
|       border-start-start-radius: 0;
 | |
|       border-end-start-radius: 0;
 | |
|       border-end-end-radius: 0;
 | |
|     }
 | |
| 
 | |
|     & > .media-gallery__item:nth-child(3) {
 | |
|       border-start-start-radius: 0;
 | |
|       border-end-start-radius: 0;
 | |
|       border-start-end-radius: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &--layout-4 {
 | |
|     min-height: calc(64px * 2 + 8px);
 | |
| 
 | |
|     & > .media-gallery__item:nth-child(1) {
 | |
|       border-end-end-radius: 0;
 | |
|       border-start-end-radius: 0;
 | |
|       border-end-start-radius: 0;
 | |
|     }
 | |
| 
 | |
|     & > .media-gallery__item:nth-child(2) {
 | |
|       border-start-start-radius: 0;
 | |
|       border-end-start-radius: 0;
 | |
|       border-end-end-radius: 0;
 | |
|     }
 | |
| 
 | |
|     & > .media-gallery__item:nth-child(3) {
 | |
|       border-start-start-radius: 0;
 | |
|       border-start-end-radius: 0;
 | |
|       border-end-start-radius: 0;
 | |
|       border-end-end-radius: 0;
 | |
|     }
 | |
| 
 | |
|     & > .media-gallery__item:nth-child(4) {
 | |
|       border-start-start-radius: 0;
 | |
|       border-end-start-radius: 0;
 | |
|       border-start-end-radius: 0;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .media-gallery__item {
 | |
|   border: 0;
 | |
|   box-sizing: border-box;
 | |
|   display: block;
 | |
|   position: relative;
 | |
|   border-radius: 8px;
 | |
|   overflow: hidden;
 | |
|   outline: 1px solid var(--media-outline-color);
 | |
|   outline-offset: -1px;
 | |
|   z-index: 1;
 | |
| 
 | |
|   &--tall {
 | |
|     grid-row: span 2;
 | |
|   }
 | |
| 
 | |
|   &--wide {
 | |
|     grid-column: span 2;
 | |
|   }
 | |
| 
 | |
|   &--square {
 | |
|     aspect-ratio: 1;
 | |
|   }
 | |
| 
 | |
|   &__overlay {
 | |
|     position: absolute;
 | |
|     top: 0;
 | |
|     inset-inline-start: 0;
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     justify-content: center;
 | |
|     box-sizing: border-box;
 | |
|     width: 100%;
 | |
|     height: 100%;
 | |
|     pointer-events: none;
 | |
|     padding: 8px;
 | |
|     z-index: 1;
 | |
| 
 | |
|     &--corner {
 | |
|       align-items: flex-start;
 | |
|       justify-content: flex-end;
 | |
|     }
 | |
| 
 | |
|     .icon {
 | |
|       color: $white;
 | |
|       filter: var(--overlay-icon-shadow);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &--error img {
 | |
|     visibility: hidden;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .media-gallery__item-thumbnail {
 | |
|   cursor: pointer;
 | |
|   display: block;
 | |
|   text-decoration: none;
 | |
|   color: $secondary-text-color;
 | |
|   position: relative;
 | |
|   z-index: -1;
 | |
| 
 | |
|   &,
 | |
|   img {
 | |
|     height: 100%;
 | |
|     width: 100%;
 | |
|   }
 | |
| 
 | |
|   img {
 | |
|     object-fit: cover;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .media-gallery__preview {
 | |
|   width: 100%;
 | |
|   height: 100%;
 | |
|   object-fit: cover;
 | |
|   position: absolute;
 | |
|   top: 0;
 | |
|   inset-inline-start: 0;
 | |
|   z-index: -2;
 | |
|   background: $base-overlay-background;
 | |
| 
 | |
|   &--hidden {
 | |
|     display: none;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .media-gallery__gifv {
 | |
|   height: 100%;
 | |
|   overflow: hidden;
 | |
|   position: relative;
 | |
|   width: 100%;
 | |
|   z-index: -1;
 | |
| }
 | |
| 
 | |
| .media-gallery__item-gifv-thumbnail {
 | |
|   cursor: pointer;
 | |
|   height: 100%;
 | |
|   object-fit: cover;
 | |
|   width: 100%;
 | |
| }
 | |
| 
 | |
| /* End Media Gallery */
 | |
| 
 | |
| .detailed,
 | |
| .fullscreen {
 | |
|   .video-player__volume__current,
 | |
|   .video-player__volume::before {
 | |
|     bottom: 27px;
 | |
|   }
 | |
| 
 | |
|   .video-player__volume__handle {
 | |
|     bottom: 23px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .audio-player {
 | |
|   box-sizing: border-box;
 | |
|   container: audio-player / inline-size;
 | |
|   position: relative;
 | |
|   overflow: hidden;
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
|   width: 100%;
 | |
|   aspect-ratio: 16 / 9;
 | |
|   color: var(--player-foreground-color);
 | |
|   background: var(--player-background-color, var(--background-color));
 | |
|   border-radius: 8px;
 | |
|   outline: 1px solid var(--media-outline-color);
 | |
|   outline-offset: -1px;
 | |
| 
 | |
|   &__controls {
 | |
|     display: grid;
 | |
|     grid-template-columns: 1fr 1fr 1fr;
 | |
|     height: 100%;
 | |
| 
 | |
|     &__play {
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       justify-content: center;
 | |
|       position: relative;
 | |
| 
 | |
|       .player-button {
 | |
|         position: absolute;
 | |
|         top: 50%;
 | |
|         inset-inline-start: 50%;
 | |
|         transform: translate(-50%, -50%);
 | |
|       }
 | |
| 
 | |
|       .icon {
 | |
|         filter: var(--overlay-icon-shadow);
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .player-button {
 | |
|       display: inline-block;
 | |
|       outline: 0;
 | |
|       padding: 5px;
 | |
|       flex: 0 0 auto;
 | |
|       background: transparent;
 | |
|       border: 0;
 | |
|       color: var(--player-foreground-color);
 | |
|       opacity: 0.75;
 | |
| 
 | |
|       .icon {
 | |
|         width: 48px;
 | |
|         height: 48px;
 | |
|       }
 | |
| 
 | |
|       &:active,
 | |
|       &:hover,
 | |
|       &:focus {
 | |
|         opacity: 1;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__visualizer {
 | |
|     width: 100%;
 | |
|     max-width: 200px;
 | |
|   }
 | |
| 
 | |
|   .video-player__seek {
 | |
|     position: absolute;
 | |
|     inset: 0 0 auto;
 | |
|     height: 24px;
 | |
|     z-index: 1; /* Ensure this renders on top of audio player controls */
 | |
|   }
 | |
| 
 | |
|   &.inactive {
 | |
|     .video-player__seek,
 | |
|     .audio-player__controls,
 | |
|     .video-player__controls {
 | |
|       visibility: hidden;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .video-player__volume::before,
 | |
|   .video-player__seek::before {
 | |
|     background: currentColor;
 | |
|     opacity: 0.15;
 | |
|   }
 | |
| 
 | |
|   .video-player__seek__buffer {
 | |
|     background: currentColor;
 | |
|     opacity: 0.2;
 | |
|   }
 | |
| 
 | |
|   .video-player__seek__progress,
 | |
|   .video-player__seek__handle,
 | |
|   .video-player__volume__current,
 | |
|   .video-player__volume__handle {
 | |
|     background-color: var(--player-accent-color);
 | |
|   }
 | |
| 
 | |
|   .video-player__buttons button,
 | |
|   .video-player__buttons a {
 | |
|     color: currentColor;
 | |
|     opacity: 0.75;
 | |
| 
 | |
|     &:active,
 | |
|     &:hover,
 | |
|     &:focus {
 | |
|       color: currentColor;
 | |
|       opacity: 1;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .video-player__time-sep,
 | |
|   .video-player__time-total,
 | |
|   .video-player__time-current {
 | |
|     color: currentColor;
 | |
|   }
 | |
| 
 | |
|   @container audio-player (max-width: 400px) {
 | |
|     .video-player__time,
 | |
|     .player-button.video-player__download__icon {
 | |
|       display: none;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .video-player__seek::before,
 | |
|   .video-player__seek__buffer,
 | |
|   .video-player__seek__progress {
 | |
|     top: 0;
 | |
|   }
 | |
| 
 | |
|   .video-player__seek__handle {
 | |
|     top: -4px;
 | |
|   }
 | |
| 
 | |
|   .video-player__controls {
 | |
|     padding-top: 10px;
 | |
|     background: transparent;
 | |
|     z-index: 1;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .video-player {
 | |
|   overflow: hidden;
 | |
|   position: relative;
 | |
|   background: $base-shadow-color;
 | |
|   max-width: 100%;
 | |
|   border-radius: 8px;
 | |
|   box-sizing: border-box;
 | |
|   color: $white;
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   outline: 1px solid var(--media-outline-color);
 | |
|   outline-offset: -1px;
 | |
|   z-index: 2;
 | |
| 
 | |
|   video {
 | |
|     display: block;
 | |
|     z-index: -2;
 | |
|   }
 | |
| 
 | |
|   &.fullscreen {
 | |
|     width: 100% !important;
 | |
|     height: 100% !important;
 | |
|     margin: 0;
 | |
|     aspect-ratio: auto !important;
 | |
|     outline: none;
 | |
|     border-radius: 0;
 | |
| 
 | |
|     video {
 | |
|       width: 100% !important;
 | |
|       height: 100% !important;
 | |
|       outline: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__controls {
 | |
|     position: absolute;
 | |
|     direction: ltr;
 | |
|     z-index: -1;
 | |
|     bottom: 0;
 | |
|     inset-inline-start: 0;
 | |
|     inset-inline-end: 0;
 | |
|     box-sizing: border-box;
 | |
|     background: linear-gradient(
 | |
|       0deg,
 | |
|       rgba($base-shadow-color, 0.85) 0,
 | |
|       rgba($base-shadow-color, 0.45) 60%,
 | |
|       transparent
 | |
|     );
 | |
|     padding: 0 15px;
 | |
|     opacity: 0;
 | |
|     pointer-events: none;
 | |
|     transition: opacity 0.1s ease;
 | |
| 
 | |
|     &.active {
 | |
|       opacity: 1;
 | |
|       pointer-events: auto;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .media-gallery__actions {
 | |
|     opacity: 0;
 | |
|     transition: opacity 0.1s ease;
 | |
| 
 | |
|     &.active {
 | |
|       opacity: 1;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.inactive {
 | |
|     video,
 | |
|     .video-player__controls {
 | |
|       visibility: hidden;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__spoiler {
 | |
|     display: none;
 | |
|     position: absolute;
 | |
|     top: 0;
 | |
|     inset-inline-start: 0;
 | |
|     width: 100%;
 | |
|     height: 100%;
 | |
|     z-index: 4;
 | |
|     border: 0;
 | |
|     background: $base-overlay-background;
 | |
|     color: $darker-text-color;
 | |
|     transition: none;
 | |
|     pointer-events: none;
 | |
| 
 | |
|     &.active {
 | |
|       display: block;
 | |
|       pointer-events: auto;
 | |
| 
 | |
|       &:hover,
 | |
|       &:active,
 | |
|       &:focus {
 | |
|         color: lighten($darker-text-color, 7%);
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &__title {
 | |
|       display: block;
 | |
|       font-size: 14px;
 | |
|     }
 | |
| 
 | |
|     &__subtitle {
 | |
|       display: block;
 | |
|       font-size: 11px;
 | |
|       font-weight: 500;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__buttons-bar {
 | |
|     display: flex;
 | |
|     justify-content: space-between;
 | |
|     padding-bottom: 8px;
 | |
|     margin: 0 -5px;
 | |
| 
 | |
|     .video-player__download__icon {
 | |
|       color: inherit;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__buttons {
 | |
|     display: flex;
 | |
|     flex: 0 1 auto;
 | |
|     min-width: 30px;
 | |
|     align-items: center;
 | |
|     white-space: nowrap;
 | |
|     overflow: hidden;
 | |
|     text-overflow: ellipsis;
 | |
|     gap: 5px;
 | |
| 
 | |
|     .player-button {
 | |
|       display: inline-block;
 | |
|       outline: 0;
 | |
|       padding: 5px;
 | |
|       flex: 0 0 auto;
 | |
|       background: transparent;
 | |
|       border: 0;
 | |
|       color: rgba($white, 0.75);
 | |
|       font-weight: 500;
 | |
| 
 | |
|       &:active,
 | |
|       &:hover,
 | |
|       &:focus {
 | |
|         color: $white;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__time {
 | |
|     display: inline;
 | |
|     flex: 0 1 auto;
 | |
|     overflow: hidden;
 | |
|     text-overflow: ellipsis;
 | |
|     margin: 0 5px;
 | |
|   }
 | |
| 
 | |
|   &__time-sep,
 | |
|   &__time-total,
 | |
|   &__time-current {
 | |
|     font-size: 14px;
 | |
|     font-weight: 500;
 | |
|   }
 | |
| 
 | |
|   &__time-current {
 | |
|     color: $white;
 | |
|   }
 | |
| 
 | |
|   &__time-sep {
 | |
|     display: inline-block;
 | |
|     margin: 0 6px;
 | |
|   }
 | |
| 
 | |
|   &__time-sep,
 | |
|   &__time-total {
 | |
|     color: $white;
 | |
|   }
 | |
| 
 | |
|   &__volume {
 | |
|     flex: 0 0 auto;
 | |
|     display: inline-flex;
 | |
|     cursor: pointer;
 | |
|     height: 24px;
 | |
|     position: relative;
 | |
|     overflow: hidden;
 | |
| 
 | |
|     .no-reduce-motion & {
 | |
|       transition: all 100ms linear;
 | |
|     }
 | |
| 
 | |
|     &.active {
 | |
|       overflow: visible;
 | |
|       width: 50px;
 | |
|       margin-inline-end: 16px;
 | |
|     }
 | |
| 
 | |
|     &::before {
 | |
|       content: '';
 | |
|       width: 50px;
 | |
|       background: rgba($white, 0.35);
 | |
|       border-radius: 4px;
 | |
|       display: block;
 | |
|       position: absolute;
 | |
|       height: 4px;
 | |
|       inset-inline-start: 0;
 | |
|       top: 50%;
 | |
|       transform: translate(0, -50%);
 | |
|     }
 | |
| 
 | |
|     &__current {
 | |
|       display: block;
 | |
|       position: absolute;
 | |
|       height: 4px;
 | |
|       border-radius: 4px;
 | |
|       inset-inline-start: 0;
 | |
|       top: 50%;
 | |
|       transform: translate(0, -50%);
 | |
|       background: $white;
 | |
|     }
 | |
| 
 | |
|     &__handle {
 | |
|       position: absolute;
 | |
|       z-index: 3;
 | |
|       border-radius: 50%;
 | |
|       width: 12px;
 | |
|       height: 12px;
 | |
|       top: 50%;
 | |
|       inset-inline-start: 0;
 | |
|       margin-inline-start: -6px;
 | |
|       transform: translate(0, -50%);
 | |
|       background: $white;
 | |
|       box-shadow: 1px 2px 6px rgba($base-shadow-color, 0.2);
 | |
|       opacity: 0;
 | |
| 
 | |
|       .no-reduce-motion & {
 | |
|         transition: opacity 100ms linear;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &.active &__handle {
 | |
|       opacity: 1;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__link {
 | |
|     padding: 2px 10px;
 | |
| 
 | |
|     a {
 | |
|       text-decoration: none;
 | |
|       font-size: 14px;
 | |
|       font-weight: 500;
 | |
|       color: $white;
 | |
| 
 | |
|       &:hover,
 | |
|       &:active,
 | |
|       &:focus {
 | |
|         text-decoration: underline;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__seek {
 | |
|     cursor: pointer;
 | |
|     height: 24px;
 | |
|     position: relative;
 | |
| 
 | |
|     &::before {
 | |
|       content: '';
 | |
|       width: 100%;
 | |
|       background: rgba($white, 0.35);
 | |
|       border-radius: 4px;
 | |
|       display: block;
 | |
|       position: absolute;
 | |
|       height: 4px;
 | |
|       top: 14px;
 | |
|     }
 | |
| 
 | |
|     &__progress,
 | |
|     &__buffer {
 | |
|       display: block;
 | |
|       position: absolute;
 | |
|       height: 4px;
 | |
|       border-radius: 4px;
 | |
|       top: 14px;
 | |
|       background: $white;
 | |
|     }
 | |
| 
 | |
|     &__buffer {
 | |
|       background: rgba($white, 0.2);
 | |
|     }
 | |
| 
 | |
|     &__handle {
 | |
|       position: absolute;
 | |
|       z-index: 3;
 | |
|       opacity: 0;
 | |
|       border-radius: 50%;
 | |
|       width: 12px;
 | |
|       height: 12px;
 | |
|       top: 10px;
 | |
|       margin-inline-start: -6px;
 | |
|       background: $white;
 | |
|       box-shadow: 1px 2px 6px rgba($base-shadow-color, 0.2);
 | |
| 
 | |
|       .no-reduce-motion & {
 | |
|         transition: opacity 0.1s ease;
 | |
|       }
 | |
| 
 | |
|       &.active {
 | |
|         opacity: 1;
 | |
|         cursor: grabbing;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &:hover {
 | |
|       .video-player__seek__handle {
 | |
|         opacity: 1;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__hotkey-indicator {
 | |
|     position: absolute;
 | |
|     top: 50%;
 | |
|     inset-inline-start: 50%;
 | |
|     transform: translate(-50%, -50%);
 | |
|     background: rgba($base-shadow-color, 0.45);
 | |
|     backdrop-filter: var(--background-filter);
 | |
|     color: $white;
 | |
|     border-radius: 8px;
 | |
|     padding: 16px 24px;
 | |
|     display: flex;
 | |
|     flex-direction: column;
 | |
|     align-items: center;
 | |
|     justify-content: center;
 | |
|     gap: 8px;
 | |
| 
 | |
|     &__label {
 | |
|       font-size: 15px;
 | |
|       font-weight: 500;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.detailed,
 | |
|   &.fullscreen {
 | |
|     .video-player__buttons {
 | |
|       .player-button {
 | |
|         padding-top: 10px;
 | |
|         padding-bottom: 10px;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .gifv {
 | |
|   position: relative;
 | |
| 
 | |
|   canvas {
 | |
|     position: absolute;
 | |
|     width: 100%;
 | |
|     height: 100%;
 | |
|   }
 | |
| 
 | |
|   video {
 | |
|     max-width: 100vw;
 | |
|     max-height: 80vh;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .scrollable .account-card {
 | |
|   margin: 10px;
 | |
| }
 | |
| 
 | |
| .scrollable .account-card__title__avatar {
 | |
|   img {
 | |
|     border: 2px solid var(--background-color);
 | |
|   }
 | |
| 
 | |
|   .account__avatar {
 | |
|     border: none;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .scrollable .account-card__header {
 | |
|   img {
 | |
|     border-radius: 4px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .scrollable .account-card__bio::after {
 | |
|   background: linear-gradient(to left, var(--background-color), transparent);
 | |
| }
 | |
| 
 | |
| .account-gallery__container {
 | |
|   display: grid;
 | |
|   grid-template-columns: 1fr 1fr 1fr;
 | |
|   gap: 2px;
 | |
| 
 | |
|   .media-gallery__item {
 | |
|     border-radius: 0;
 | |
|   }
 | |
| 
 | |
|   .load-more,
 | |
|   .timeline-hint {
 | |
|     grid-column: span 3;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .notification__filter-bar,
 | |
| .account__section-headline {
 | |
|   border: 1px solid var(--background-border-color);
 | |
|   border-top: 0;
 | |
|   cursor: default;
 | |
|   display: flex;
 | |
|   flex-shrink: 0;
 | |
| 
 | |
|   @media screen and (max-width: $no-gap-breakpoint - 1px) {
 | |
|     border-right: 0;
 | |
|     border-left: 0;
 | |
|   }
 | |
| 
 | |
|   button {
 | |
|     background: transparent;
 | |
|     border: 0;
 | |
|     margin: 0;
 | |
|   }
 | |
| 
 | |
|   button,
 | |
|   a {
 | |
|     display: block;
 | |
|     flex: 1 1 auto;
 | |
|     color: $darker-text-color;
 | |
|     padding: 15px 0;
 | |
|     font-size: 14px;
 | |
|     font-weight: 500;
 | |
|     text-align: center;
 | |
|     text-decoration: none;
 | |
|     position: relative;
 | |
|     width: 100%;
 | |
|     white-space: nowrap;
 | |
| 
 | |
|     &.active {
 | |
|       color: $primary-text-color;
 | |
| 
 | |
|       &::before {
 | |
|         display: block;
 | |
|         content: '';
 | |
|         position: absolute;
 | |
|         bottom: -1px;
 | |
|         left: 50%;
 | |
|         transform: translateX(-50%);
 | |
|         width: 40px;
 | |
|         height: 3px;
 | |
|         border-radius: 4px 4px 0 0;
 | |
|         background: $highlight-text-color;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .scrollable & {
 | |
|     border-left: 0;
 | |
|     border-right: 0;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .filter-form {
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
| 
 | |
|   &__column {
 | |
|     display: flex;
 | |
|     flex-direction: column;
 | |
|     gap: 15px;
 | |
|     padding: 15px;
 | |
|   }
 | |
| 
 | |
|   .radio-button {
 | |
|     display: flex;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .column-settings__row .radio-button {
 | |
|   display: flex;
 | |
| }
 | |
| 
 | |
| .radio-button,
 | |
| .check-box {
 | |
|   font-size: 14px;
 | |
|   position: relative;
 | |
|   display: inline-flex;
 | |
|   align-items: center;
 | |
|   line-height: 18px;
 | |
|   white-space: nowrap;
 | |
|   overflow: hidden;
 | |
|   text-overflow: ellipsis;
 | |
|   cursor: pointer;
 | |
|   gap: 10px;
 | |
|   color: $secondary-text-color;
 | |
| 
 | |
|   input[type='radio'],
 | |
|   input[type='checkbox'] {
 | |
|     display: none;
 | |
|   }
 | |
| 
 | |
|   &__input {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     justify-content: center;
 | |
|     position: relative;
 | |
|     border: 2px solid $secondary-text-color;
 | |
|     box-sizing: border-box;
 | |
|     width: 20px;
 | |
|     height: 20px;
 | |
|     flex: 0 0 auto;
 | |
|     border-radius: 50%;
 | |
| 
 | |
|     &.checked,
 | |
|     &.indeterminate {
 | |
|       border-color: $ui-highlight-color;
 | |
|     }
 | |
| 
 | |
|     .icon {
 | |
|       width: 18px;
 | |
|       height: 18px;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .radio-button__input.checked::before {
 | |
|   content: '';
 | |
|   display: block;
 | |
|   border-radius: 50%;
 | |
|   width: calc(100% - 4px);
 | |
|   height: calc(100% - 4px);
 | |
|   background: $ui-highlight-color;
 | |
| }
 | |
| 
 | |
| .check-box {
 | |
|   &__input {
 | |
|     width: 18px;
 | |
|     height: 18px;
 | |
|     border-radius: 2px;
 | |
| 
 | |
|     &.checked,
 | |
|     &.indeterminate {
 | |
|       background: $ui-highlight-color;
 | |
|       color: $white;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| noscript {
 | |
|   text-align: center;
 | |
| 
 | |
|   img {
 | |
|     width: 200px;
 | |
|     opacity: 0.5;
 | |
|     animation: flicker 4s infinite;
 | |
|   }
 | |
| 
 | |
|   div {
 | |
|     font-size: 14px;
 | |
|     margin: 30px auto;
 | |
|     color: $secondary-text-color;
 | |
|     max-width: 400px;
 | |
| 
 | |
|     a {
 | |
|       color: $highlight-text-color;
 | |
|       text-decoration: underline;
 | |
| 
 | |
|       &:hover {
 | |
|         text-decoration: none;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| @keyframes flicker {
 | |
|   0% {
 | |
|     opacity: 1;
 | |
|   }
 | |
| 
 | |
|   30% {
 | |
|     opacity: 0.75;
 | |
|   }
 | |
| 
 | |
|   100% {
 | |
|     opacity: 1;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .moved-account-banner,
 | |
| .follow-request-banner,
 | |
| .account-memorial-banner {
 | |
|   padding: 20px;
 | |
|   background: var(--surface-background-color);
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   flex-direction: column;
 | |
| 
 | |
|   &__message {
 | |
|     color: $darker-text-color;
 | |
|     padding: 8px 0;
 | |
|     padding-top: 0;
 | |
|     padding-bottom: 4px;
 | |
|     font-size: 14px;
 | |
|     font-weight: 500;
 | |
|     text-align: center;
 | |
|     margin-bottom: 16px;
 | |
|   }
 | |
| 
 | |
|   &__action {
 | |
|     display: flex;
 | |
|     justify-content: space-between;
 | |
|     align-items: center;
 | |
|     gap: 15px;
 | |
|     width: 100%;
 | |
|   }
 | |
| 
 | |
|   .detailed-status__display-name {
 | |
|     margin-bottom: 0;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .follow-request-banner .button {
 | |
|   width: 100%;
 | |
| }
 | |
| 
 | |
| .account-memorial-banner__message {
 | |
|   margin-bottom: 0;
 | |
| }
 | |
| 
 | |
| .column-inline-form {
 | |
|   padding: 15px;
 | |
|   display: flex;
 | |
|   justify-content: flex-start;
 | |
|   gap: 15px;
 | |
|   align-items: center;
 | |
|   border: 1px solid var(--background-border-color);
 | |
|   border-top: 0;
 | |
| 
 | |
|   label {
 | |
|     flex: 1 1 auto;
 | |
| 
 | |
|     input {
 | |
|       width: 100%;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   @media screen and (max-width: $no-gap-breakpoint) {
 | |
|     border-left: 0;
 | |
|     border-right: 0;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .drawer__backdrop {
 | |
|   cursor: pointer;
 | |
|   position: absolute;
 | |
|   top: 0;
 | |
|   inset-inline-start: 0;
 | |
|   width: 100%;
 | |
|   height: 100%;
 | |
|   background: rgba($base-overlay-background, 0.5);
 | |
| }
 | |
| 
 | |
| .focal-point {
 | |
|   position: relative;
 | |
|   cursor: grab;
 | |
|   overflow: hidden;
 | |
|   display: flex;
 | |
|   justify-content: center;
 | |
|   align-items: center;
 | |
| 
 | |
|   &.dragging {
 | |
|     cursor: grabbing;
 | |
|   }
 | |
| 
 | |
|   &__reticle {
 | |
|     position: absolute;
 | |
|     width: 100px;
 | |
|     height: 100px;
 | |
|     transform: translate(-50%, -50%);
 | |
|     border: 2px solid #fff;
 | |
|     border-radius: 50%;
 | |
|     box-shadow: 0 0 0 9999em rgba($base-shadow-color, 0.35);
 | |
|     pointer-events: none;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .account__header__content {
 | |
|   color: $darker-text-color;
 | |
|   font-size: 14px;
 | |
|   font-weight: 400;
 | |
|   overflow: hidden;
 | |
|   word-break: normal;
 | |
|   word-wrap: break-word;
 | |
| 
 | |
|   p {
 | |
|     margin-bottom: 20px;
 | |
|     unicode-bidi: plaintext;
 | |
| 
 | |
|     &:last-child {
 | |
|       margin-bottom: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   a {
 | |
|     color: inherit;
 | |
|     text-decoration: underline;
 | |
| 
 | |
|     &:hover {
 | |
|       text-decoration: none;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .account__header {
 | |
|   overflow: hidden;
 | |
|   container: account-header / inline-size;
 | |
| 
 | |
|   &.inactive {
 | |
|     opacity: 0.5;
 | |
| 
 | |
|     .account__header__image,
 | |
|     .account__avatar {
 | |
|       filter: grayscale(100%);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__info {
 | |
|     position: absolute;
 | |
|     top: 20px;
 | |
|     inset-inline-end: 20px;
 | |
|     display: flex;
 | |
|     flex-wrap: wrap;
 | |
|     gap: 2px;
 | |
|   }
 | |
| 
 | |
|   &__image {
 | |
|     overflow: hidden;
 | |
|     height: 145px;
 | |
|     position: relative;
 | |
|     background: darken($ui-base-color, 4%);
 | |
|     border-bottom: 1px solid var(--background-border-color);
 | |
| 
 | |
|     img {
 | |
|       object-fit: cover;
 | |
|       display: block;
 | |
|       width: 100%;
 | |
|       height: 100%;
 | |
|       margin: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__bar {
 | |
|     position: relative;
 | |
|     padding: 0 20px;
 | |
|     border-bottom: 1px solid var(--background-border-color);
 | |
| 
 | |
|     .avatar {
 | |
|       display: block;
 | |
|       flex: 0 0 auto;
 | |
| 
 | |
|       .account__avatar {
 | |
|         background: var(--background-color);
 | |
|         border: 1px solid var(--background-border-color);
 | |
|         border-radius: var(--avatar-border-radius);
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__badges {
 | |
|     display: flex;
 | |
|     flex-wrap: wrap;
 | |
|     gap: 8px;
 | |
| 
 | |
|     .account-role {
 | |
|       line-height: unset;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__tabs {
 | |
|     display: flex;
 | |
|     align-items: flex-start;
 | |
|     justify-content: space-between;
 | |
|     margin-top: -55px;
 | |
|     padding-top: 10px;
 | |
|     gap: 8px;
 | |
|     overflow: hidden;
 | |
|     margin-inline-start: -2px; // aligns the pfp with content below
 | |
| 
 | |
|     &__buttons {
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       gap: 8px;
 | |
|       padding-top: 55px;
 | |
|       overflow: hidden;
 | |
| 
 | |
|       .button {
 | |
|         flex-shrink: 1;
 | |
|         white-space: nowrap;
 | |
|         min-width: 80px;
 | |
|       }
 | |
| 
 | |
|       .icon-button {
 | |
|         border: 1px solid var(--background-border-color);
 | |
|         border-radius: 4px;
 | |
|         box-sizing: content-box;
 | |
|         padding: 5px;
 | |
| 
 | |
|         .icon {
 | |
|           width: 24px;
 | |
|           height: 24px;
 | |
|         }
 | |
| 
 | |
|         &.copied {
 | |
|           border-color: $valid-value-color;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .optional {
 | |
|         @container account-header (max-width: 372px) {
 | |
|           display: none;
 | |
|         }
 | |
| 
 | |
|         // Fallback for older browsers with no container queries support
 | |
|         @media screen and (max-width: 372px + 55px) {
 | |
|           display: none;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &__name {
 | |
|       margin-top: 16px;
 | |
|       margin-bottom: 16px;
 | |
| 
 | |
|       .emojione {
 | |
|         width: 22px;
 | |
|         height: 22px;
 | |
|       }
 | |
| 
 | |
|       h1 {
 | |
|         font-size: 17px;
 | |
|         line-height: 22px;
 | |
|         color: $primary-text-color;
 | |
|         font-weight: 600;
 | |
|         overflow: hidden;
 | |
|         white-space: nowrap;
 | |
|         text-overflow: ellipsis;
 | |
| 
 | |
|         small {
 | |
|           display: flex;
 | |
|           align-items: center;
 | |
|           gap: 4px;
 | |
|           font-size: 14px;
 | |
|           line-height: 20px;
 | |
|           color: $darker-text-color;
 | |
|           font-weight: 400;
 | |
|           overflow: hidden;
 | |
|           text-overflow: ellipsis;
 | |
| 
 | |
|           span {
 | |
|             overflow: hidden;
 | |
|             text-overflow: ellipsis;
 | |
|             user-select: all;
 | |
|           }
 | |
| 
 | |
|           .icon-lock {
 | |
|             height: 18px;
 | |
|             width: 18px;
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .spacer {
 | |
|       flex: 1 1 auto;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__bio {
 | |
|     .account__header__content {
 | |
|       color: $primary-text-color;
 | |
|     }
 | |
| 
 | |
|     .account__header__fields {
 | |
|       margin: 0;
 | |
|       margin-top: 16px;
 | |
|       border-radius: 4px;
 | |
|       border: 1px solid var(--background-border-color);
 | |
| 
 | |
|       dl {
 | |
|         display: block;
 | |
|         padding: 11px 16px;
 | |
|         border-bottom-color: var(--background-border-color);
 | |
|       }
 | |
| 
 | |
|       dd,
 | |
|       dt {
 | |
|         font-size: 13px;
 | |
|         line-height: 18px;
 | |
|         padding: 0;
 | |
|         text-align: initial;
 | |
|       }
 | |
| 
 | |
|       dt {
 | |
|         width: auto;
 | |
|         background: transparent;
 | |
|         text-transform: uppercase;
 | |
|         color: $dark-text-color;
 | |
|       }
 | |
| 
 | |
|       dd {
 | |
|         color: $darker-text-color;
 | |
|       }
 | |
| 
 | |
|       a {
 | |
|         color: lighten($ui-highlight-color, 8%);
 | |
|       }
 | |
| 
 | |
|       .icon {
 | |
|         width: 18px;
 | |
|         height: 18px;
 | |
|       }
 | |
| 
 | |
|       .verified {
 | |
|         border: 1px solid rgba($valid-value-color, 0.5);
 | |
|         margin-top: -1px;
 | |
|         margin-inline: -1px;
 | |
| 
 | |
|         &:first-child {
 | |
|           border-top-left-radius: 4px;
 | |
|           border-top-right-radius: 4px;
 | |
|         }
 | |
| 
 | |
|         &:last-child {
 | |
|           border-bottom-left-radius: 4px;
 | |
|           border-bottom-right-radius: 4px;
 | |
|           margin-bottom: -1px;
 | |
|         }
 | |
| 
 | |
|         dt,
 | |
|         dd {
 | |
|           color: $valid-value-color;
 | |
|         }
 | |
| 
 | |
|         dd {
 | |
|           display: flex;
 | |
|           align-items: center;
 | |
|           gap: 4px;
 | |
| 
 | |
|           span {
 | |
|             display: flex;
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         a {
 | |
|           color: $valid-value-color;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__extra {
 | |
|     margin-top: 16px;
 | |
| 
 | |
|     &__links {
 | |
|       font-size: 14px;
 | |
|       color: $darker-text-color;
 | |
|       margin: 0 -10px;
 | |
|       padding-top: 16px;
 | |
|       padding-bottom: 10px;
 | |
| 
 | |
|       a {
 | |
|         display: inline-block;
 | |
|         color: $darker-text-color;
 | |
|         text-decoration: none;
 | |
|         padding: 5px 10px;
 | |
|         font-weight: 500;
 | |
| 
 | |
|         strong {
 | |
|           font-weight: 700;
 | |
|           color: $primary-text-color;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__account-note {
 | |
|     color: $primary-text-color;
 | |
|     font-size: 14px;
 | |
|     font-weight: 400;
 | |
|     margin-bottom: 10px;
 | |
| 
 | |
|     &__loading-indicator-wrapper {
 | |
|       position: relative;
 | |
|       height: 37px;
 | |
| 
 | |
|       .loading-indicator {
 | |
|         left: 10px;
 | |
|       }
 | |
| 
 | |
|       .circular-progress {
 | |
|         width: 14px;
 | |
|         height: 14px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     label {
 | |
|       display: block;
 | |
|       font-size: 12px;
 | |
|       font-weight: 500;
 | |
|       color: $darker-text-color;
 | |
|       text-transform: uppercase;
 | |
|       margin-bottom: 5px;
 | |
|     }
 | |
| 
 | |
|     textarea {
 | |
|       display: block;
 | |
|       box-sizing: border-box;
 | |
|       width: calc(100% + 20px);
 | |
|       color: $secondary-text-color;
 | |
|       background: transparent;
 | |
|       padding: 10px;
 | |
|       margin: 0 -10px;
 | |
|       font-family: inherit;
 | |
|       font-size: 14px;
 | |
|       resize: none;
 | |
|       border: 0;
 | |
|       outline: 0;
 | |
|       border-radius: 4px;
 | |
| 
 | |
|       &::placeholder {
 | |
|         color: $dark-text-color;
 | |
|         opacity: 1;
 | |
|       }
 | |
| 
 | |
|       &:focus {
 | |
|         background: $ui-base-color;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__familiar-followers {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     gap: 10px;
 | |
|     margin-block: 16px;
 | |
|     color: $darker-text-color;
 | |
| 
 | |
|     a:any-link {
 | |
|       font-weight: 500;
 | |
|       text-decoration: none;
 | |
|       color: $primary-text-color;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .account__contents {
 | |
|   overflow: hidden;
 | |
| }
 | |
| 
 | |
| .account__details {
 | |
|   display: flex;
 | |
|   flex-wrap: wrap;
 | |
|   column-gap: 1em;
 | |
| }
 | |
| 
 | |
| .verified-badge {
 | |
|   display: inline-flex;
 | |
|   align-items: center;
 | |
|   color: $valid-value-color;
 | |
|   gap: 4px;
 | |
|   overflow: hidden;
 | |
|   white-space: nowrap;
 | |
| 
 | |
|   > span {
 | |
|     overflow: hidden;
 | |
|     text-overflow: ellipsis;
 | |
|   }
 | |
| 
 | |
|   a {
 | |
|     color: inherit;
 | |
|     font-weight: 500;
 | |
|     text-decoration: none;
 | |
|   }
 | |
| 
 | |
|   .icon {
 | |
|     width: 16px;
 | |
|     height: 16px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .trends {
 | |
|   &__item {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     padding: 16px;
 | |
|     border-bottom: 1px solid var(--background-border-color);
 | |
|     gap: 8px;
 | |
| 
 | |
|     &__name {
 | |
|       flex: 1 1 auto;
 | |
|       color: $dark-text-color;
 | |
|       overflow: hidden;
 | |
|       text-overflow: ellipsis;
 | |
|       white-space: nowrap;
 | |
| 
 | |
|       strong {
 | |
|         font-weight: 500;
 | |
|       }
 | |
| 
 | |
|       a {
 | |
|         color: $darker-text-color;
 | |
|         text-decoration: none;
 | |
|         font-size: 14px;
 | |
|         font-weight: 500;
 | |
|         display: block;
 | |
|         overflow: hidden;
 | |
|         text-overflow: ellipsis;
 | |
|         white-space: nowrap;
 | |
| 
 | |
|         &:hover,
 | |
|         &:focus,
 | |
|         &:active {
 | |
|           span {
 | |
|             text-decoration: underline;
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &__current {
 | |
|       flex: 0 0 auto;
 | |
|       font-size: 24px;
 | |
|       font-weight: 500;
 | |
|       text-align: end;
 | |
|       color: $secondary-text-color;
 | |
|       text-decoration: none;
 | |
|     }
 | |
| 
 | |
|     &__sparkline {
 | |
|       flex: 0 0 auto;
 | |
|       width: 50px;
 | |
| 
 | |
|       path:first-child {
 | |
|         fill: rgba($highlight-text-color, 0.25) !important;
 | |
|         fill-opacity: 1 !important;
 | |
|       }
 | |
| 
 | |
|       path:last-child {
 | |
|         stroke: lighten($highlight-text-color, 6%) !important;
 | |
|         fill: none !important;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &--requires-review {
 | |
|       .trends__item__name {
 | |
|         color: $gold-star;
 | |
| 
 | |
|         a {
 | |
|           color: $gold-star;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .trends__item__current {
 | |
|         color: $gold-star;
 | |
|       }
 | |
| 
 | |
|       .trends__item__sparkline {
 | |
|         path:first-child {
 | |
|           fill: rgba($gold-star, 0.25) !important;
 | |
|         }
 | |
| 
 | |
|         path:last-child {
 | |
|           stroke: lighten($gold-star, 6%) !important;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &--disabled {
 | |
|       .trends__item__name {
 | |
|         color: lighten($ui-base-color, 12%);
 | |
| 
 | |
|         a {
 | |
|           color: lighten($ui-base-color, 12%);
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .trends__item__current {
 | |
|         color: lighten($ui-base-color, 12%);
 | |
|       }
 | |
| 
 | |
|       .trends__item__sparkline {
 | |
|         path:first-child {
 | |
|           fill: rgba(lighten($ui-base-color, 12%), 0.25) !important;
 | |
|         }
 | |
| 
 | |
|         path:last-child {
 | |
|           stroke: lighten(lighten($ui-base-color, 12%), 6%) !important;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &--compact &__item {
 | |
|     padding: 12px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .conversation {
 | |
|   display: flex;
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
|   padding: 5px;
 | |
|   padding-bottom: 0;
 | |
| 
 | |
|   &:focus {
 | |
|     background: lighten($ui-base-color, 2%);
 | |
|     outline: 0;
 | |
|   }
 | |
| 
 | |
|   &__avatar {
 | |
|     flex: 0 0 auto;
 | |
|     padding: 10px;
 | |
|     padding-top: 12px;
 | |
|     position: relative;
 | |
|     cursor: pointer;
 | |
|   }
 | |
| 
 | |
|   &__unread {
 | |
|     display: inline-block;
 | |
|     background: $highlight-text-color;
 | |
|     border-radius: 50%;
 | |
|     width: 0.625rem;
 | |
|     height: 0.625rem;
 | |
|     margin: -0.1ex 0.15em 0.1ex;
 | |
|   }
 | |
| 
 | |
|   &__content {
 | |
|     flex: 1 1 auto;
 | |
|     padding: 10px 5px;
 | |
|     padding-inline-end: 15px;
 | |
|     overflow: hidden;
 | |
| 
 | |
|     &__info {
 | |
|       overflow: hidden;
 | |
|       display: flex;
 | |
|       flex-direction: row-reverse;
 | |
|       justify-content: space-between;
 | |
|     }
 | |
| 
 | |
|     &__relative-time {
 | |
|       font-size: 15px;
 | |
|       color: $darker-text-color;
 | |
|       padding-inline-start: 15px;
 | |
|     }
 | |
| 
 | |
|     &__names {
 | |
|       color: $darker-text-color;
 | |
|       font-size: 15px;
 | |
|       white-space: nowrap;
 | |
|       overflow: hidden;
 | |
|       text-overflow: ellipsis;
 | |
|       margin-bottom: 4px;
 | |
|       flex-basis: 90px;
 | |
|       flex-grow: 1;
 | |
| 
 | |
|       a {
 | |
|         color: $primary-text-color;
 | |
|         text-decoration: none;
 | |
| 
 | |
|         &:hover,
 | |
|         &:focus,
 | |
|         &:active {
 | |
|           text-decoration: underline;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     a {
 | |
|       overflow-wrap: anywhere;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .announcements {
 | |
|   background: lighten($ui-base-color, 8%);
 | |
|   font-size: 13px;
 | |
|   display: flex;
 | |
|   align-items: flex-end;
 | |
| 
 | |
|   &__mastodon {
 | |
|     width: 124px;
 | |
|     flex: 0 0 auto;
 | |
| 
 | |
|     @media screen and (max-width: 124px + 300px) {
 | |
|       display: none;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__container {
 | |
|     width: calc(100% - 124px);
 | |
|     flex: 0 0 auto;
 | |
|     position: relative;
 | |
| 
 | |
|     @media screen and (max-width: 124px + 300px) {
 | |
|       width: 100%;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__item {
 | |
|     box-sizing: border-box;
 | |
|     width: 100%;
 | |
|     padding: 15px;
 | |
|     position: relative;
 | |
|     font-size: 15px;
 | |
|     line-height: 20px;
 | |
|     word-wrap: break-word;
 | |
|     font-weight: 400;
 | |
|     max-height: 50vh;
 | |
|     overflow: hidden;
 | |
|     display: flex;
 | |
|     flex-direction: column;
 | |
| 
 | |
|     &__range {
 | |
|       display: block;
 | |
|       font-weight: 500;
 | |
|       margin-bottom: 10px;
 | |
|       padding-inline-end: 18px;
 | |
|     }
 | |
| 
 | |
|     &__unread {
 | |
|       position: absolute;
 | |
|       top: 19px;
 | |
|       inset-inline-end: 19px;
 | |
|       display: block;
 | |
|       background: $highlight-text-color;
 | |
|       border-radius: 50%;
 | |
|       width: 0.625rem;
 | |
|       height: 0.625rem;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__pagination {
 | |
|     padding: 15px;
 | |
|     color: $darker-text-color;
 | |
|     position: absolute;
 | |
|     bottom: 3px;
 | |
|     inset-inline-end: 0;
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .layout-multiple-columns .announcements__mastodon {
 | |
|   display: none;
 | |
| }
 | |
| 
 | |
| .layout-multiple-columns .announcements__container {
 | |
|   width: 100%;
 | |
| }
 | |
| 
 | |
| .reactions-bar {
 | |
|   display: flex;
 | |
|   flex-wrap: wrap;
 | |
|   align-items: center;
 | |
|   margin-top: 15px;
 | |
|   margin-inline-start: -2px;
 | |
|   width: calc(100% - (90px - 33px));
 | |
| 
 | |
|   &__item {
 | |
|     flex-shrink: 0;
 | |
|     background: lighten($ui-base-color, 12%);
 | |
|     color: $darker-text-color;
 | |
|     border: 0;
 | |
|     border-radius: 3px;
 | |
|     margin: 2px;
 | |
|     cursor: pointer;
 | |
|     user-select: none;
 | |
|     padding: 0 6px;
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     transition: all 100ms ease-in;
 | |
|     transition-property: background-color, color;
 | |
| 
 | |
|     &__emoji {
 | |
|       display: block;
 | |
|       margin: 3px 0;
 | |
|       width: 16px;
 | |
|       height: 16px;
 | |
| 
 | |
|       img {
 | |
|         display: block;
 | |
|         margin: 0;
 | |
|         width: 100%;
 | |
|         height: 100%;
 | |
|         min-width: auto;
 | |
|         min-height: auto;
 | |
|         vertical-align: bottom;
 | |
|         object-fit: contain;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &__count {
 | |
|       display: block;
 | |
|       min-width: 9px;
 | |
|       font-size: 13px;
 | |
|       font-weight: 500;
 | |
|       text-align: center;
 | |
|       margin-inline-start: 6px;
 | |
|     }
 | |
| 
 | |
|     &:hover,
 | |
|     &:focus,
 | |
|     &:active {
 | |
|       background: lighten($ui-base-color, 16%);
 | |
|       transition: all 200ms ease-out;
 | |
|       transition-property: background-color, color;
 | |
|       color: lighten($darker-text-color, 4%);
 | |
|     }
 | |
| 
 | |
|     &.active {
 | |
|       transition: all 100ms ease-in;
 | |
|       transition-property: background-color, color;
 | |
|       background-color: color.mix(
 | |
|         lighten($ui-base-color, 12%),
 | |
|         $ui-highlight-color,
 | |
|         80%
 | |
|       );
 | |
|       color: lighten($highlight-text-color, 8%);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .emoji-picker-dropdown {
 | |
|     margin: 2px;
 | |
|   }
 | |
| 
 | |
|   &:hover .emoji-button {
 | |
|     opacity: 0.85;
 | |
|   }
 | |
| 
 | |
|   .emoji-button {
 | |
|     color: $darker-text-color;
 | |
|     margin: 0;
 | |
|     font-size: 16px;
 | |
|     width: auto;
 | |
|     flex-shrink: 0;
 | |
|     padding: 0 6px;
 | |
|     height: 22px;
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     opacity: 0.5;
 | |
|     transition: all 100ms ease-in;
 | |
|     transition-property: background-color, color;
 | |
| 
 | |
|     &:hover,
 | |
|     &:active,
 | |
|     &:focus {
 | |
|       opacity: 1;
 | |
|       color: lighten($darker-text-color, 4%);
 | |
|       transition: all 200ms ease-out;
 | |
|       transition-property: background-color, color;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &--empty {
 | |
|     .emoji-button {
 | |
|       padding: 0;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .notification,
 | |
| .status__wrapper,
 | |
| .conversation {
 | |
|   position: relative;
 | |
| 
 | |
|   &.unread {
 | |
|     &::before {
 | |
|       content: '';
 | |
|       position: absolute;
 | |
|       top: 0;
 | |
|       inset-inline-start: 0;
 | |
|       width: 100%;
 | |
|       height: 100%;
 | |
|       border-inline-start: 4px solid $highlight-text-color;
 | |
|       pointer-events: none;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .picture-in-picture {
 | |
|   position: fixed;
 | |
|   bottom: 20px;
 | |
|   inset-inline-end: 20px;
 | |
|   width: 300px;
 | |
|   box-shadow: var(--dropdown-shadow);
 | |
| 
 | |
|   &__footer {
 | |
|     border-radius: 0 0 4px 4px;
 | |
|     background: var(--modal-background-variant-color);
 | |
|     backdrop-filter: var(--background-filter);
 | |
|     border: 1px solid var(--modal-border-color);
 | |
|     border-top: 0;
 | |
|     padding: 12px;
 | |
|     display: flex;
 | |
|     justify-content: space-between;
 | |
|   }
 | |
| 
 | |
|   &__header {
 | |
|     border-radius: 4px 4px 0 0;
 | |
|     background: var(--modal-background-variant-color);
 | |
|     backdrop-filter: var(--background-filter);
 | |
|     border: 1px solid var(--modal-border-color);
 | |
|     border-bottom: 0;
 | |
|     padding: 12px;
 | |
|     display: flex;
 | |
|     justify-content: space-between;
 | |
| 
 | |
|     .icon-button {
 | |
|       padding: 6px;
 | |
|     }
 | |
| 
 | |
|     &__account {
 | |
|       display: flex;
 | |
|       text-decoration: none;
 | |
|       overflow: hidden;
 | |
|     }
 | |
| 
 | |
|     .account__avatar {
 | |
|       margin-inline-end: 8px;
 | |
|     }
 | |
| 
 | |
|     .display-name {
 | |
|       color: $primary-text-color;
 | |
|       text-decoration: none;
 | |
| 
 | |
|       strong,
 | |
|       span {
 | |
|         display: block;
 | |
|         text-overflow: ellipsis;
 | |
|         overflow: hidden;
 | |
|       }
 | |
| 
 | |
|       span {
 | |
|         color: $darker-text-color;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .video-player,
 | |
|   .audio-player {
 | |
|     border-radius: 0;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .picture-in-picture-placeholder {
 | |
|   border-radius: 8px;
 | |
|   box-sizing: border-box;
 | |
|   border: 1px dashed var(--background-border-color);
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
|   align-items: center;
 | |
|   justify-content: center;
 | |
|   margin-top: 16px;
 | |
|   font-size: 15px;
 | |
|   line-height: 21px;
 | |
|   font-weight: 500;
 | |
|   cursor: pointer;
 | |
|   color: $dark-text-color;
 | |
|   aspect-ratio: 16 / 9;
 | |
| 
 | |
|   .icon {
 | |
|     width: 48px;
 | |
|     height: 48px;
 | |
|     margin-bottom: 8px;
 | |
|   }
 | |
| 
 | |
|   &:hover,
 | |
|   &:active,
 | |
|   &:focus {
 | |
|     color: $darker-text-color;
 | |
|   }
 | |
| 
 | |
|   &:focus-visible {
 | |
|     outline: $ui-button-focus-outline;
 | |
|     border-color: transparent;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .notifications-permission-banner {
 | |
|   padding: 30px;
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
|   align-items: center;
 | |
|   justify-content: center;
 | |
|   position: relative;
 | |
| 
 | |
|   &__close {
 | |
|     position: absolute;
 | |
|     top: 10px;
 | |
|     inset-inline-end: 10px;
 | |
|   }
 | |
| 
 | |
|   h2 {
 | |
|     font-size: 16px;
 | |
|     font-weight: 500;
 | |
|     margin-bottom: 15px;
 | |
|     text-align: center;
 | |
|   }
 | |
| 
 | |
|   p {
 | |
|     color: $darker-text-color;
 | |
|     margin-bottom: 15px;
 | |
|     text-align: center;
 | |
| 
 | |
|     .icon {
 | |
|       width: 20px;
 | |
|       height: 20px;
 | |
|       vertical-align: middle;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .explore__search-header {
 | |
|   justify-content: center;
 | |
|   align-items: center;
 | |
|   border: 1px solid var(--background-border-color);
 | |
|   border-top: 0;
 | |
|   border-bottom: 0;
 | |
|   padding: 16px;
 | |
|   padding-bottom: 8px;
 | |
| 
 | |
|   .search {
 | |
|     width: 100%;
 | |
|     margin-bottom: 0;
 | |
|   }
 | |
| 
 | |
|   .search__input {
 | |
|     border: 1px solid var(--background-border-color);
 | |
|     padding: 12px;
 | |
|     padding-inline-end: 30px;
 | |
|   }
 | |
| 
 | |
|   .search__popout {
 | |
|     border: 1px solid var(--background-border-color);
 | |
|   }
 | |
| 
 | |
|   .search__icon {
 | |
|     top: 12px;
 | |
|     inset-inline-end: 12px;
 | |
|     color: $dark-text-color;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .layout-single-column .explore__search-header {
 | |
|   display: none;
 | |
| 
 | |
|   @media screen and (max-width: $no-gap-breakpoint - 1px) {
 | |
|     display: flex;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .explore__search-results {
 | |
|   flex: 1 1 auto;
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
| 
 | |
|   @media screen and (min-width: $no-gap-breakpoint) {
 | |
|     border: 1px solid var(--background-border-color);
 | |
|     border-top: 0;
 | |
|     border-bottom-left-radius: 4px;
 | |
|     border-bottom-right-radius: 4px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .story {
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   color: $primary-text-color;
 | |
|   padding: 16px;
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
|   gap: 16px;
 | |
| 
 | |
|   &:last-child {
 | |
|     border-bottom: 0;
 | |
|   }
 | |
| 
 | |
|   &__details {
 | |
|     flex: 1 1 auto;
 | |
| 
 | |
|     &__publisher {
 | |
|       color: $darker-text-color;
 | |
|       margin-bottom: 8px;
 | |
|       font-size: 14px;
 | |
|       line-height: 20px;
 | |
|     }
 | |
| 
 | |
|     &__title {
 | |
|       display: block;
 | |
|       font-size: 19px;
 | |
|       line-height: 24px;
 | |
|       font-weight: 500;
 | |
|       margin-bottom: 8px;
 | |
|       text-decoration: none;
 | |
|       color: $primary-text-color;
 | |
| 
 | |
|       &:hover,
 | |
|       &:active,
 | |
|       &:focus {
 | |
|         color: $highlight-text-color;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &__shared {
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       color: $darker-text-color;
 | |
|       gap: 8px;
 | |
|       justify-content: space-between;
 | |
|       font-size: 14px;
 | |
|       line-height: 20px;
 | |
| 
 | |
|       & > span {
 | |
|         display: flex;
 | |
|         align-items: center;
 | |
|         gap: 4px;
 | |
|       }
 | |
| 
 | |
|       &__pill {
 | |
|         background: var(--surface-variant-background-color);
 | |
|         border-radius: 4px;
 | |
|         color: inherit;
 | |
|         text-decoration: none;
 | |
|         padding: 4px 12px;
 | |
|         font-size: 12px;
 | |
|         font-weight: 500;
 | |
|         line-height: 16px;
 | |
|       }
 | |
| 
 | |
|       &__author-link {
 | |
|         display: inline-flex;
 | |
|         align-items: center;
 | |
|         gap: 4px;
 | |
|         color: $primary-text-color;
 | |
|         font-weight: 500;
 | |
|         text-decoration: none;
 | |
| 
 | |
|         &:hover,
 | |
|         &:active,
 | |
|         &:focus {
 | |
|           color: $highlight-text-color;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     strong {
 | |
|       font-weight: 500;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__thumbnail {
 | |
|     flex: 0 0 auto;
 | |
|     position: relative;
 | |
|     width: 120px;
 | |
|     aspect-ratio: 1;
 | |
| 
 | |
|     .skeleton {
 | |
|       width: 100%;
 | |
|       height: 100%;
 | |
|     }
 | |
| 
 | |
|     img {
 | |
|       border-radius: 8px;
 | |
|       display: block;
 | |
|       margin: 0;
 | |
|       width: 100%;
 | |
|       height: 100%;
 | |
|       object-fit: cover;
 | |
|     }
 | |
| 
 | |
|     &__preview {
 | |
|       border-radius: 8px;
 | |
|       display: block;
 | |
|       margin: 0;
 | |
|       width: 100%;
 | |
|       height: 100%;
 | |
|       object-fit: fill;
 | |
|       position: absolute;
 | |
|       top: 0;
 | |
|       inset-inline-start: 0;
 | |
|       z-index: 0;
 | |
| 
 | |
|       &--hidden {
 | |
|         display: none;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.expanded {
 | |
|     flex-direction: column;
 | |
| 
 | |
|     .story__thumbnail {
 | |
|       order: 1;
 | |
|       width: 100%;
 | |
|       height: auto;
 | |
|       aspect-ratio: 1.91 / 1;
 | |
|     }
 | |
| 
 | |
|     .story__details {
 | |
|       order: 2;
 | |
|       width: 100%;
 | |
|       flex: 0 0 auto;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .server-banner {
 | |
|   &__introduction {
 | |
|     font-size: 15px;
 | |
|     line-height: 22px;
 | |
|     color: $darker-text-color;
 | |
|     margin-bottom: 20px;
 | |
| 
 | |
|     strong {
 | |
|       font-weight: 700;
 | |
|     }
 | |
| 
 | |
|     a {
 | |
|       color: inherit;
 | |
|       text-decoration: underline;
 | |
| 
 | |
|       &:hover,
 | |
|       &:active,
 | |
|       &:focus {
 | |
|         text-decoration: none;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__hero {
 | |
|     display: block;
 | |
|     border-radius: 4px;
 | |
|     width: 100%;
 | |
|     height: auto;
 | |
|     margin-bottom: 20px;
 | |
|     aspect-ratio: 1.9;
 | |
|     border: 0;
 | |
|     background: $ui-base-color;
 | |
|     object-fit: cover;
 | |
|   }
 | |
| 
 | |
|   &__description {
 | |
|     font-size: 15px;
 | |
|     line-height: 22px;
 | |
|     color: $darker-text-color;
 | |
|     margin-bottom: 20px;
 | |
|   }
 | |
| 
 | |
|   &__meta {
 | |
|     display: flex;
 | |
|     gap: 10px;
 | |
|     max-width: 100%;
 | |
| 
 | |
|     &__column {
 | |
|       flex: 0 0 auto;
 | |
|       width: calc(50% - 5px);
 | |
|       overflow: hidden;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__number {
 | |
|     font-weight: 600;
 | |
|     color: $primary-text-color;
 | |
|     font-size: 14px;
 | |
|   }
 | |
| 
 | |
|   &__number-label {
 | |
|     color: $darker-text-color;
 | |
|     font-weight: 500;
 | |
|     font-size: 14px;
 | |
|   }
 | |
| 
 | |
|   h4 {
 | |
|     text-transform: uppercase;
 | |
|     color: $darker-text-color;
 | |
|     margin-bottom: 10px;
 | |
|     font-weight: 600;
 | |
|   }
 | |
| 
 | |
|   .account {
 | |
|     padding: 0;
 | |
|     border: 0;
 | |
|   }
 | |
| 
 | |
|   .account__avatar-wrapper {
 | |
|     margin-inline-start: 0;
 | |
|   }
 | |
| 
 | |
|   .spacer {
 | |
|     margin: 10px 0;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .safety-action-modal,
 | |
| .interaction-modal {
 | |
|   max-width: 100vw;
 | |
|   width: 600px;
 | |
|   overflow-y: auto;
 | |
| }
 | |
| 
 | |
| .interaction-modal {
 | |
|   overflow: visible;
 | |
|   position: relative;
 | |
|   display: block;
 | |
|   border-radius: 16px;
 | |
|   background: var(--modal-background-color);
 | |
|   backdrop-filter: var(--background-filter);
 | |
|   border: 1px solid var(--modal-border-color);
 | |
|   padding: 24px;
 | |
|   box-sizing: border-box;
 | |
| 
 | |
|   @media screen and (max-width: $mobile-breakpoint) {
 | |
|     border-radius: 16px 16px 0 0;
 | |
|     border-bottom: 0;
 | |
|     padding-bottom: 32px;
 | |
|   }
 | |
| 
 | |
|   h3 {
 | |
|     font-size: 22px;
 | |
|     line-height: 33px;
 | |
|     font-weight: 700;
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     justify-content: center;
 | |
|     gap: 8px;
 | |
|   }
 | |
| 
 | |
|   p {
 | |
|     text-align: center;
 | |
|     font-size: 17px;
 | |
|     line-height: 22px;
 | |
|     color: $darker-text-color;
 | |
| 
 | |
|     strong {
 | |
|       color: $primary-text-color;
 | |
|       font-weight: 700;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   p.hint {
 | |
|     margin-bottom: 14px;
 | |
|     font-size: 14px;
 | |
|   }
 | |
| 
 | |
|   &__icon {
 | |
|     color: $highlight-text-color;
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     justify-content: center;
 | |
|   }
 | |
| 
 | |
|   &__lead {
 | |
|     margin-bottom: 20px;
 | |
| 
 | |
|     h3 {
 | |
|       margin-bottom: 15px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__login {
 | |
|     position: relative;
 | |
|     margin-bottom: 20px;
 | |
| 
 | |
|     &__input {
 | |
|       @include search-input;
 | |
| 
 | |
|       border: 1px solid var(--background-border-color);
 | |
|       padding: 4px 6px;
 | |
|       color: $primary-text-color;
 | |
|       font-size: 16px;
 | |
|       line-height: 18px;
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
| 
 | |
|       input {
 | |
|         background: transparent;
 | |
|         color: inherit;
 | |
|         font: inherit;
 | |
|         border: 0;
 | |
|         padding: 15px - 4px 15px - 6px;
 | |
|         flex: 1 1 auto;
 | |
|         min-width: 0;
 | |
| 
 | |
|         &::placeholder {
 | |
|           color: lighten($darker-text-color, 4%);
 | |
|         }
 | |
| 
 | |
|         &:focus {
 | |
|           outline: 0;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .button {
 | |
|         flex: 0 0 auto;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .search__popout {
 | |
|       margin-top: -1px;
 | |
|       padding-top: 5px;
 | |
|       padding-bottom: 5px;
 | |
|       border: 1px solid var(--background-border-color);
 | |
|     }
 | |
| 
 | |
|     &.invalid &__input {
 | |
|       border-color: $error-red;
 | |
|     }
 | |
| 
 | |
|     &.expanded .search__popout {
 | |
|       display: block;
 | |
|     }
 | |
| 
 | |
|     &.expanded &__input {
 | |
|       border-radius: 4px 4px 0 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__choices {
 | |
|     display: flex;
 | |
|     gap: 40px;
 | |
| 
 | |
|     &__choice {
 | |
|       flex: 1;
 | |
|       box-sizing: border-box;
 | |
| 
 | |
|       h3 {
 | |
|         margin-bottom: 20px;
 | |
|       }
 | |
| 
 | |
|       p {
 | |
|         color: $darker-text-color;
 | |
|         margin-bottom: 20px;
 | |
|         font-size: 15px;
 | |
|       }
 | |
| 
 | |
|       .button {
 | |
|         margin-bottom: 10px;
 | |
| 
 | |
|         &:last-child {
 | |
|           margin-bottom: 0;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   @media screen and (max-width: $no-gap-breakpoint - 1px) {
 | |
|     &__choices {
 | |
|       flex-direction: column;
 | |
| 
 | |
|       &__choice {
 | |
|         margin-top: 40px;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .link-button {
 | |
|     font-size: inherit;
 | |
|     display: inline;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .copypaste {
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   gap: 10px;
 | |
| 
 | |
|   input {
 | |
|     display: block;
 | |
|     font-family: inherit;
 | |
|     background: darken($ui-base-color, 8%);
 | |
|     border: 1px solid $highlight-text-color;
 | |
|     color: $darker-text-color;
 | |
|     border-radius: 4px;
 | |
|     padding: 6px 9px;
 | |
|     line-height: 22px;
 | |
|     font-size: 14px;
 | |
|     transition: border-color 300ms linear;
 | |
|     flex: 1 1 auto;
 | |
|     overflow: hidden;
 | |
| 
 | |
|     &:focus {
 | |
|       outline: 0;
 | |
|       background: darken($ui-base-color, 4%);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .button {
 | |
|     flex: 0 0 auto;
 | |
|     transition: background 300ms linear;
 | |
|   }
 | |
| 
 | |
|   &.copied {
 | |
|     input {
 | |
|       border: 1px solid $valid-value-color;
 | |
|       transition: none;
 | |
|     }
 | |
| 
 | |
|     .button {
 | |
|       background: $valid-value-color;
 | |
|       transition: none;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .privacy-policy {
 | |
|   padding: 20px;
 | |
| 
 | |
|   @media screen and (min-width: $no-gap-breakpoint) {
 | |
|     border-radius: 4px;
 | |
|   }
 | |
| 
 | |
|   &__body {
 | |
|     margin-top: 20px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .prose {
 | |
|   color: $secondary-text-color;
 | |
|   font-size: 15px;
 | |
|   line-height: 22px;
 | |
| 
 | |
|   p,
 | |
|   ul,
 | |
|   ol {
 | |
|     margin-top: 1.25em;
 | |
|     margin-bottom: 1.25em;
 | |
|   }
 | |
| 
 | |
|   img {
 | |
|     margin-top: 2em;
 | |
|     margin-bottom: 2em;
 | |
|     max-width: 100%;
 | |
|   }
 | |
| 
 | |
|   video {
 | |
|     margin-top: 2em;
 | |
|     margin-bottom: 2em;
 | |
|     max-width: 100%;
 | |
|   }
 | |
| 
 | |
|   figure {
 | |
|     margin-top: 2em;
 | |
|     margin-bottom: 2em;
 | |
| 
 | |
|     figcaption {
 | |
|       font-size: 0.875em;
 | |
|       line-height: 1.4285714;
 | |
|       margin-top: 0.8571429em;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   figure > * {
 | |
|     margin-top: 0;
 | |
|     margin-bottom: 0;
 | |
|   }
 | |
| 
 | |
|   h1 {
 | |
|     font-size: 1.5em;
 | |
|     margin-top: 0;
 | |
|     margin-bottom: 1em;
 | |
|     line-height: 1.33;
 | |
|   }
 | |
| 
 | |
|   h2 {
 | |
|     font-size: 1.25em;
 | |
|     margin-top: 1.6em;
 | |
|     margin-bottom: 0.6em;
 | |
|     line-height: 1.6;
 | |
|   }
 | |
| 
 | |
|   h3,
 | |
|   h4,
 | |
|   h5,
 | |
|   h6 {
 | |
|     margin-top: 1.5em;
 | |
|     margin-bottom: 0.5em;
 | |
|     line-height: 1.5;
 | |
|   }
 | |
| 
 | |
|   ol {
 | |
|     counter-reset: list-counter;
 | |
|   }
 | |
| 
 | |
|   li {
 | |
|     margin-top: 0.5em;
 | |
|     margin-bottom: 0.5em;
 | |
|   }
 | |
| 
 | |
|   ol > li {
 | |
|     counter-increment: list-counter;
 | |
| 
 | |
|     &::before {
 | |
|       content: counter(list-counter) '.';
 | |
|       position: absolute;
 | |
|       inset-inline-start: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   ul > li::before {
 | |
|     content: '';
 | |
|     position: absolute;
 | |
|     background-color: $darker-text-color;
 | |
|     border-radius: 50%;
 | |
|     width: 0.375em;
 | |
|     height: 0.375em;
 | |
|     top: 0.5em;
 | |
|     inset-inline-start: 0.25em;
 | |
|   }
 | |
| 
 | |
|   ul > li,
 | |
|   ol > li {
 | |
|     position: relative;
 | |
|     padding-inline-start: 1.75em;
 | |
|   }
 | |
| 
 | |
|   & > ul > li p {
 | |
|     margin-top: 0.75em;
 | |
|     margin-bottom: 0.75em;
 | |
|   }
 | |
| 
 | |
|   & > ul > li > *:first-child {
 | |
|     margin-top: 1.25em;
 | |
|   }
 | |
| 
 | |
|   & > ul > li > *:last-child {
 | |
|     margin-bottom: 1.25em;
 | |
|   }
 | |
| 
 | |
|   & > ol > li > *:first-child {
 | |
|     margin-top: 1.25em;
 | |
|   }
 | |
| 
 | |
|   & > ol > li > *:last-child {
 | |
|     margin-bottom: 1.25em;
 | |
|   }
 | |
| 
 | |
|   ul ul,
 | |
|   ul ol,
 | |
|   ol ul,
 | |
|   ol ol {
 | |
|     margin-top: 0.75em;
 | |
|     margin-bottom: 0.75em;
 | |
|   }
 | |
| 
 | |
|   h1,
 | |
|   h2,
 | |
|   h3,
 | |
|   h4,
 | |
|   h5,
 | |
|   h6,
 | |
|   strong,
 | |
|   b {
 | |
|     color: $primary-text-color;
 | |
|     font-weight: 700;
 | |
|   }
 | |
| 
 | |
|   em,
 | |
|   i {
 | |
|     font-style: italic;
 | |
|   }
 | |
| 
 | |
|   a {
 | |
|     color: $highlight-text-color;
 | |
|     text-decoration: underline;
 | |
| 
 | |
|     &:focus,
 | |
|     &:hover,
 | |
|     &:active {
 | |
|       text-decoration: none;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   code {
 | |
|     font-size: 0.875em;
 | |
|     background: darken($ui-base-color, 8%);
 | |
|     border-radius: 4px;
 | |
|     padding: 0.2em 0.3em;
 | |
|   }
 | |
| 
 | |
|   hr {
 | |
|     border: 0;
 | |
|     border-top: 1px solid lighten($ui-base-color, 4%);
 | |
|     margin-top: 3em;
 | |
|     margin-bottom: 3em;
 | |
|   }
 | |
| 
 | |
|   hr + * {
 | |
|     margin-top: 0;
 | |
|   }
 | |
| 
 | |
|   h2 + * {
 | |
|     margin-top: 0;
 | |
|   }
 | |
| 
 | |
|   h3 + * {
 | |
|     margin-top: 0;
 | |
|   }
 | |
| 
 | |
|   h4 + *,
 | |
|   h5 + *,
 | |
|   h6 + * {
 | |
|     margin-top: 0;
 | |
|   }
 | |
| 
 | |
|   & > :first-child {
 | |
|     margin-top: 0;
 | |
|   }
 | |
| 
 | |
|   & > :last-child {
 | |
|     margin-bottom: 0;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .dismissable-banner,
 | |
| .warning-banner {
 | |
|   position: relative;
 | |
|   margin: 10px;
 | |
|   margin-bottom: 5px;
 | |
|   border-radius: 8px;
 | |
|   border: 1px solid $highlight-text-color;
 | |
|   background: rgba($highlight-text-color, 0.15);
 | |
|   overflow: hidden;
 | |
|   flex-shrink: 0;
 | |
| 
 | |
|   &__background-image {
 | |
|     width: 125%;
 | |
|     position: absolute;
 | |
|     bottom: -25%;
 | |
|     inset-inline-end: -25%;
 | |
|     z-index: -1;
 | |
|     opacity: 0.15;
 | |
|     mix-blend-mode: luminosity;
 | |
|   }
 | |
| 
 | |
|   &__message {
 | |
|     flex: 1 1 auto;
 | |
|     padding: 15px;
 | |
|     font-size: 15px;
 | |
|     line-height: 22px;
 | |
|     font-weight: 500;
 | |
|     color: $primary-text-color;
 | |
| 
 | |
|     p {
 | |
|       margin-bottom: 15px;
 | |
| 
 | |
|       &:last-child {
 | |
|         margin-bottom: 0;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     h1 {
 | |
|       color: $highlight-text-color;
 | |
|       font-size: 22px;
 | |
|       line-height: 33px;
 | |
|       font-weight: 700;
 | |
|       margin-bottom: 15px;
 | |
|     }
 | |
| 
 | |
|     &__actions {
 | |
|       display: flex;
 | |
|       flex-wrap: wrap;
 | |
|       gap: 4px;
 | |
| 
 | |
|       &__wrapper {
 | |
|         display: flex;
 | |
|         margin-top: 30px;
 | |
|       }
 | |
| 
 | |
|       .button {
 | |
|         display: block;
 | |
|         flex-grow: 1;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .button-tertiary {
 | |
|       background: rgba($ui-base-color, 0.15);
 | |
|       backdrop-filter: blur(8px);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__action {
 | |
|     float: right;
 | |
|     padding: 15px 10px;
 | |
| 
 | |
|     .icon-button {
 | |
|       color: $highlight-text-color;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .warning-banner {
 | |
|   border: 1px solid $warning-red;
 | |
|   background: rgba($warning-red, 0.15);
 | |
| 
 | |
|   &__message {
 | |
|     h1 {
 | |
|       color: $warning-red;
 | |
|     }
 | |
| 
 | |
|     a {
 | |
|       color: $primary-text-color;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .image {
 | |
|   position: relative;
 | |
|   overflow: hidden;
 | |
| 
 | |
|   &__preview {
 | |
|     position: absolute;
 | |
|     top: 0;
 | |
|     inset-inline-start: 0;
 | |
|     width: 100%;
 | |
|     height: 100%;
 | |
|     object-fit: cover;
 | |
|   }
 | |
| 
 | |
|   &.loaded &__preview {
 | |
|     display: none;
 | |
|   }
 | |
| 
 | |
|   img {
 | |
|     display: block;
 | |
|     width: 100%;
 | |
|     height: 100%;
 | |
|     object-fit: cover;
 | |
|     border: 0;
 | |
|     background: transparent;
 | |
|     opacity: 0;
 | |
|   }
 | |
| 
 | |
|   &.loaded img {
 | |
|     opacity: 1;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .link-footer {
 | |
|   flex: 0 0 auto;
 | |
|   padding-top: 20px;
 | |
|   z-index: 1;
 | |
|   font-size: 13px;
 | |
| 
 | |
|   .column & {
 | |
|     padding: 15px;
 | |
|   }
 | |
| 
 | |
|   p {
 | |
|     color: $dark-text-color;
 | |
|     margin-bottom: 20px;
 | |
| 
 | |
|     .version {
 | |
|       white-space: nowrap;
 | |
|     }
 | |
| 
 | |
|     strong {
 | |
|       font-weight: 500;
 | |
|     }
 | |
| 
 | |
|     a {
 | |
|       color: $dark-text-color;
 | |
|       text-decoration: underline;
 | |
| 
 | |
|       &:hover,
 | |
|       &:focus,
 | |
|       &:active {
 | |
|         text-decoration: none;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .about {
 | |
|   padding: 20px;
 | |
|   border-top: 1px solid var(--background-border-color);
 | |
| 
 | |
|   @media screen and (min-width: $no-gap-breakpoint) {
 | |
|     border-radius: 4px;
 | |
|   }
 | |
| 
 | |
|   &__footer {
 | |
|     color: $dark-text-color;
 | |
|     text-align: center;
 | |
|     font-size: 15px;
 | |
|     line-height: 22px;
 | |
|     margin-top: 20px;
 | |
|   }
 | |
| 
 | |
|   &__header {
 | |
|     margin-bottom: 30px;
 | |
| 
 | |
|     &__hero {
 | |
|       width: 100%;
 | |
|       height: auto;
 | |
|       aspect-ratio: 1.9;
 | |
|       background: lighten($ui-base-color, 4%);
 | |
|       border-radius: 8px;
 | |
|       margin-bottom: 30px;
 | |
|     }
 | |
| 
 | |
|     h1,
 | |
|     p {
 | |
|       text-align: center;
 | |
|     }
 | |
| 
 | |
|     h1 {
 | |
|       font-size: 24px;
 | |
|       line-height: 1.5;
 | |
|       font-weight: 700;
 | |
|       margin-bottom: 10px;
 | |
|     }
 | |
| 
 | |
|     p {
 | |
|       font-size: 16px;
 | |
|       line-height: 24px;
 | |
|       font-weight: 400;
 | |
|       color: $darker-text-color;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__meta {
 | |
|     border: 1px solid var(--background-border-color);
 | |
|     border-radius: 4px;
 | |
|     display: flex;
 | |
|     margin-bottom: 30px;
 | |
|     font-size: 15px;
 | |
| 
 | |
|     &__column {
 | |
|       box-sizing: border-box;
 | |
|       width: 50%;
 | |
|       padding: 20px;
 | |
|     }
 | |
| 
 | |
|     &__divider {
 | |
|       width: 0;
 | |
|       border: 0;
 | |
|       border-style: solid;
 | |
|       border-color: var(--background-border-color);
 | |
|       border-left-width: 1px;
 | |
|       min-height: calc(100% - 60px);
 | |
|       flex: 0 0 auto;
 | |
|     }
 | |
| 
 | |
|     h4 {
 | |
|       font-size: 15px;
 | |
|       text-transform: uppercase;
 | |
|       color: $darker-text-color;
 | |
|       font-weight: 500;
 | |
|       margin-bottom: 20px;
 | |
|     }
 | |
| 
 | |
|     @media screen and (width <= 600px) {
 | |
|       display: block;
 | |
| 
 | |
|       h4 {
 | |
|         text-align: center;
 | |
|       }
 | |
| 
 | |
|       &__column {
 | |
|         width: 100%;
 | |
|         display: flex;
 | |
|         flex-direction: column;
 | |
|         align-items: center;
 | |
|       }
 | |
| 
 | |
|       &__divider {
 | |
|         min-height: 0;
 | |
|         width: 100%;
 | |
|         border-left-width: 0;
 | |
|         border-top-width: 1px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .layout-multiple-columns & {
 | |
|       display: block;
 | |
| 
 | |
|       h4 {
 | |
|         text-align: center;
 | |
|       }
 | |
| 
 | |
|       &__column {
 | |
|         width: 100%;
 | |
|         display: flex;
 | |
|         flex-direction: column;
 | |
|         align-items: center;
 | |
|       }
 | |
| 
 | |
|       &__divider {
 | |
|         min-height: 0;
 | |
|         width: 100%;
 | |
|         border-left-width: 0;
 | |
|         border-top-width: 1px;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__mail {
 | |
|     color: $primary-text-color;
 | |
|     text-decoration: none;
 | |
|     font-weight: 500;
 | |
| 
 | |
|     &:hover,
 | |
|     &:focus,
 | |
|     &:active {
 | |
|       text-decoration: underline;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .link-footer {
 | |
|     padding: 0;
 | |
|     margin-top: 60px;
 | |
|     text-align: center;
 | |
|     font-size: 15px;
 | |
|     line-height: 22px;
 | |
| 
 | |
|     @media screen and (min-width: $no-gap-breakpoint) {
 | |
|       display: none;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .account {
 | |
|     padding: 0;
 | |
|     border: 0;
 | |
|   }
 | |
| 
 | |
|   .account__avatar-wrapper {
 | |
|     margin-inline-start: 0;
 | |
|   }
 | |
| 
 | |
|   .account__relationship {
 | |
|     display: none;
 | |
|   }
 | |
| 
 | |
|   &__section {
 | |
|     margin-bottom: 10px;
 | |
| 
 | |
|     &__title {
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       gap: 6px;
 | |
|       font-size: 17px;
 | |
|       font-weight: 600;
 | |
|       line-height: 22px;
 | |
|       padding: 20px;
 | |
|       border-radius: 4px;
 | |
|       border: 1px solid var(--background-border-color);
 | |
|       color: $highlight-text-color;
 | |
|       cursor: pointer;
 | |
|       width: 100%;
 | |
|       background: none;
 | |
|     }
 | |
| 
 | |
|     &.active &__title {
 | |
|       border-radius: 4px 4px 0 0;
 | |
|     }
 | |
| 
 | |
|     &__body {
 | |
|       border: 1px solid var(--background-border-color);
 | |
|       border-top: 0;
 | |
|       padding: 20px;
 | |
|       font-size: 15px;
 | |
|       line-height: 22px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__domain-blocks {
 | |
|     margin-top: 30px;
 | |
|     border: 1px solid var(--background-border-color);
 | |
|     border-radius: 4px;
 | |
| 
 | |
|     &__domain {
 | |
|       border-bottom: 1px solid var(--background-border-color);
 | |
|       padding: 10px;
 | |
|       font-size: 15px;
 | |
|       color: $darker-text-color;
 | |
| 
 | |
|       &:nth-child(2n) {
 | |
|         background: darken($ui-base-color, 4%);
 | |
|       }
 | |
| 
 | |
|       &:last-child {
 | |
|         border-bottom: 0;
 | |
|       }
 | |
| 
 | |
|       &__header {
 | |
|         display: flex;
 | |
|         gap: 10px;
 | |
|         justify-content: space-between;
 | |
|         font-weight: 500;
 | |
|         margin-bottom: 4px;
 | |
|       }
 | |
| 
 | |
|       h6 {
 | |
|         color: $secondary-text-color;
 | |
|         font-size: inherit;
 | |
|         white-space: nowrap;
 | |
|         overflow: hidden;
 | |
|         text-overflow: ellipsis;
 | |
|       }
 | |
| 
 | |
|       p {
 | |
|         white-space: nowrap;
 | |
|         overflow: hidden;
 | |
|         text-overflow: ellipsis;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .notification-list {
 | |
|   position: fixed;
 | |
|   bottom: 2rem;
 | |
|   inset-inline-start: 0;
 | |
|   z-index: 9999;
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
|   gap: 4px;
 | |
| }
 | |
| 
 | |
| .notification-bar {
 | |
|   flex: 0 0 auto;
 | |
|   position: relative;
 | |
|   inset-inline-start: -100%;
 | |
|   width: auto;
 | |
|   padding: 15px;
 | |
|   margin: 0;
 | |
|   color: $white;
 | |
|   background: rgba($black, 0.85);
 | |
|   backdrop-filter: blur(8px);
 | |
|   border: 1px solid rgba(lighten($classic-base-color, 4%), 0.85);
 | |
|   border-radius: 8px;
 | |
|   box-shadow:
 | |
|     0 10px 15px -3px rgba($base-shadow-color, 0.25),
 | |
|     0 4px 6px -4px rgba($base-shadow-color, 0.25);
 | |
|   cursor: default;
 | |
|   font-size: 15px;
 | |
|   line-height: 21px;
 | |
| 
 | |
|   &.notification-bar-active {
 | |
|     inset-inline-start: 1rem;
 | |
|   }
 | |
| 
 | |
|   .no-reduce-motion & {
 | |
|     transition: 0.5s cubic-bezier(0.89, 0.01, 0.5, 1.1);
 | |
|     transform: translateZ(0);
 | |
|   }
 | |
| }
 | |
| 
 | |
| .notification-bar-title {
 | |
|   margin-inline-end: 5px;
 | |
| }
 | |
| 
 | |
| .notification-bar-title,
 | |
| .notification-bar-action {
 | |
|   font-weight: 700;
 | |
| }
 | |
| 
 | |
| .notification-bar-action {
 | |
|   display: inline-block;
 | |
|   border: 0;
 | |
|   background: transparent;
 | |
|   text-transform: uppercase;
 | |
|   margin-inline-start: 10px;
 | |
|   cursor: pointer;
 | |
|   color: $blurple-300;
 | |
|   border-radius: 4px;
 | |
|   padding: 0 4px;
 | |
| 
 | |
|   &:hover,
 | |
|   &:focus,
 | |
|   &:active {
 | |
|     background: rgba($ui-base-color, 0.85);
 | |
|   }
 | |
| }
 | |
| 
 | |
| .hashtag-header {
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
|   padding: 15px;
 | |
|   font-size: 17px;
 | |
|   line-height: 22px;
 | |
|   color: $darker-text-color;
 | |
| 
 | |
|   strong {
 | |
|     font-weight: 700;
 | |
|   }
 | |
| 
 | |
|   &__header {
 | |
|     display: flex;
 | |
|     justify-content: space-between;
 | |
|     align-items: center;
 | |
|     margin-bottom: 15px;
 | |
|     gap: 15px;
 | |
| 
 | |
|     h1 {
 | |
|       color: $primary-text-color;
 | |
|       white-space: nowrap;
 | |
|       text-overflow: ellipsis;
 | |
|       overflow: hidden;
 | |
|       font-size: 22px;
 | |
|       line-height: 33px;
 | |
|       font-weight: 700;
 | |
|     }
 | |
| 
 | |
|     &__buttons {
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       gap: 8px;
 | |
| 
 | |
|       .button {
 | |
|         flex-shrink: 1;
 | |
|         white-space: nowrap;
 | |
|         min-width: 80px;
 | |
|       }
 | |
| 
 | |
|       .icon-button {
 | |
|         border: 1px solid var(--background-border-color);
 | |
|         border-radius: 4px;
 | |
|         box-sizing: content-box;
 | |
|         padding: 5px;
 | |
| 
 | |
|         .icon {
 | |
|           width: 24px;
 | |
|           height: 24px;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .hashtag-bar {
 | |
|   margin-top: 16px;
 | |
|   display: flex;
 | |
|   flex-wrap: wrap;
 | |
|   font-size: 12px;
 | |
|   line-height: 16px;
 | |
|   gap: 6px;
 | |
|   color: $darker-text-color;
 | |
| 
 | |
|   a {
 | |
|     display: inline-flex;
 | |
|     color: inherit;
 | |
|     text-decoration: none;
 | |
|     padding: 4px 12px;
 | |
|     background: var(--surface-variant-background-color);
 | |
|     border-radius: 4px;
 | |
|     font-weight: 500;
 | |
| 
 | |
|     &:hover,
 | |
|     &:focus,
 | |
|     &:active {
 | |
|       background: var(--surface-variant-active-background-color);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .link-button {
 | |
|     color: inherit;
 | |
|     font-size: inherit;
 | |
|     line-height: inherit;
 | |
|     padding: 0;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .inline-follow-suggestions {
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
|   gap: 12px;
 | |
|   padding: 16px 0;
 | |
|   padding-bottom: 0;
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
|   background: rgba($ui-highlight-color, 0.05);
 | |
| 
 | |
|   &__header {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     justify-content: space-between;
 | |
|     padding: 0 16px;
 | |
| 
 | |
|     h3 {
 | |
|       font-size: 15px;
 | |
|       line-height: 22px;
 | |
|       font-weight: 500;
 | |
|     }
 | |
| 
 | |
|     &__actions {
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       gap: 24px;
 | |
|     }
 | |
| 
 | |
|     .link-button {
 | |
|       font-size: 13px;
 | |
|       font-weight: 500;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__body {
 | |
|     position: relative;
 | |
| 
 | |
|     &__scroll-button {
 | |
|       position: absolute;
 | |
|       height: 100%;
 | |
|       background: transparent;
 | |
|       border: none;
 | |
|       cursor: pointer;
 | |
|       top: 0;
 | |
|       color: $primary-text-color;
 | |
|       opacity: 0.5;
 | |
| 
 | |
|       &.left {
 | |
|         left: 0;
 | |
|       }
 | |
| 
 | |
|       &.right {
 | |
|         right: 0;
 | |
|       }
 | |
| 
 | |
|       &__icon {
 | |
|         border-radius: 50%;
 | |
|         background: $ui-highlight-color;
 | |
|         display: flex;
 | |
|         align-items: center;
 | |
|         justify-content: center;
 | |
|         aspect-ratio: 1;
 | |
|         padding: 8px;
 | |
| 
 | |
|         .icon {
 | |
|           width: 24px;
 | |
|           height: 24px;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       &:hover,
 | |
|       &:focus,
 | |
|       &:active {
 | |
|         opacity: 1;
 | |
| 
 | |
|         .inline-follow-suggestions__body__scroll-button__icon {
 | |
|           background: lighten($ui-highlight-color, 4%);
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &__scrollable {
 | |
|       display: flex;
 | |
|       flex-wrap: nowrap;
 | |
|       gap: 16px;
 | |
|       padding: 16px;
 | |
|       scroll-snap-type: x mandatory;
 | |
|       scroll-padding: 16px;
 | |
|       scroll-behavior: smooth;
 | |
|       overflow-x: scroll;
 | |
|       scrollbar-width: none;
 | |
| 
 | |
|       &__card {
 | |
|         background: var(--background-color);
 | |
|         border: 1px solid var(--background-border-color);
 | |
|         border-radius: 4px;
 | |
|         display: flex;
 | |
|         flex-direction: column;
 | |
|         gap: 12px;
 | |
|         align-items: center;
 | |
|         padding: 12px;
 | |
|         scroll-snap-align: start;
 | |
|         flex: 0 0 auto;
 | |
|         width: 200px;
 | |
|         box-sizing: border-box;
 | |
|         position: relative;
 | |
| 
 | |
|         a {
 | |
|           text-decoration: none;
 | |
|         }
 | |
| 
 | |
|         & > .icon-button {
 | |
|           position: absolute;
 | |
|           inset-inline-end: 8px;
 | |
|           top: 8px;
 | |
|           opacity: 0.75;
 | |
|         }
 | |
| 
 | |
|         &__avatar {
 | |
|           height: 48px;
 | |
|           display: flex;
 | |
| 
 | |
|           a {
 | |
|             display: flex;
 | |
|             text-decoration: none;
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         .account__avatar {
 | |
|           flex-shrink: 0;
 | |
|           align-self: flex-end;
 | |
|           border: 1px solid var(--background-border-color);
 | |
|           background-color: $ui-base-color;
 | |
|         }
 | |
| 
 | |
|         &__text-stack {
 | |
|           display: flex;
 | |
|           flex-direction: column;
 | |
|           gap: 4px;
 | |
|           align-items: center;
 | |
|           max-width: 100%;
 | |
| 
 | |
|           a {
 | |
|             max-width: 100%;
 | |
|           }
 | |
| 
 | |
|           &__source {
 | |
|             display: inline-flex;
 | |
|             align-items: center;
 | |
|             color: $dark-text-color;
 | |
|             gap: 4px;
 | |
|             overflow: hidden;
 | |
|             white-space: nowrap;
 | |
|             cursor: help;
 | |
| 
 | |
|             > span {
 | |
|               overflow: hidden;
 | |
|               text-overflow: ellipsis;
 | |
|             }
 | |
| 
 | |
|             .icon {
 | |
|               width: 16px;
 | |
|               height: 16px;
 | |
|             }
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         .display-name {
 | |
|           display: flex;
 | |
|           flex-direction: column;
 | |
|           gap: 4px;
 | |
|           align-items: center;
 | |
| 
 | |
|           & > * {
 | |
|             max-width: 100%;
 | |
|           }
 | |
| 
 | |
|           &__html {
 | |
|             font-size: 15px;
 | |
|             font-weight: 500;
 | |
|             color: $secondary-text-color;
 | |
|           }
 | |
| 
 | |
|           &__account {
 | |
|             font-size: 14px;
 | |
|             color: $darker-text-color;
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         .verified-badge {
 | |
|           font-size: 14px;
 | |
|           max-width: 100%;
 | |
|         }
 | |
| 
 | |
|         .button {
 | |
|           display: block;
 | |
|           width: 100%;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .filtered-notifications-banner {
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
|   padding: 16px 24px;
 | |
|   gap: 8px;
 | |
|   color: $darker-text-color;
 | |
|   text-decoration: none;
 | |
| 
 | |
|   &:hover,
 | |
|   &:active,
 | |
|   &:focus {
 | |
|     color: $secondary-text-color;
 | |
|   }
 | |
| 
 | |
|   .notification-group__icon {
 | |
|     color: inherit;
 | |
|   }
 | |
| 
 | |
|   &__text {
 | |
|     flex: 1 1 auto;
 | |
|     font-size: 14px;
 | |
|     line-height: 20px;
 | |
| 
 | |
|     strong {
 | |
|       font-size: 16px;
 | |
|       line-height: 24px;
 | |
|       display: block;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__badge {
 | |
|     background: $ui-button-background-color;
 | |
|     color: $white;
 | |
|     border-radius: 100px;
 | |
|     padding: 2px 8px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .notification-request {
 | |
|   $padding: 15px;
 | |
| 
 | |
|   display: flex;
 | |
|   padding: $padding;
 | |
|   gap: 8px;
 | |
|   position: relative;
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
| 
 | |
|   &__checkbox {
 | |
|     position: absolute;
 | |
|     inset-inline-start: $padding;
 | |
|     top: 50%;
 | |
|     transform: translateY(-50%);
 | |
|     width: 0;
 | |
|     overflow: hidden;
 | |
|     opacity: 0;
 | |
| 
 | |
|     .check-box {
 | |
|       display: flex;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__link {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     gap: 12px;
 | |
|     flex: 1 1 auto;
 | |
|     text-decoration: none;
 | |
|     color: inherit;
 | |
|     overflow: hidden;
 | |
| 
 | |
|     .account__avatar {
 | |
|       flex-shrink: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__name {
 | |
|     flex: 1 1 auto;
 | |
|     color: $darker-text-color;
 | |
|     font-size: 14px;
 | |
|     line-height: 20px;
 | |
|     overflow: hidden;
 | |
|     text-overflow: ellipsis;
 | |
| 
 | |
|     &__display-name {
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       gap: 6px;
 | |
|       font-size: 16px;
 | |
|       letter-spacing: 0.5px;
 | |
|       line-height: 24px;
 | |
|       color: $secondary-text-color;
 | |
| 
 | |
|       bdi {
 | |
|         overflow: hidden;
 | |
|         white-space: nowrap;
 | |
|         text-overflow: ellipsis;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .filtered-notifications-banner__badge {
 | |
|       background: $ui-button-background-color;
 | |
|       border-radius: 4px;
 | |
|       padding: 1px 6px;
 | |
|       color: $white;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__actions {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     gap: 8px;
 | |
| 
 | |
|     .icon-button {
 | |
|       border-radius: 4px;
 | |
|       border: 1px solid var(--background-border-color);
 | |
|       padding: 5px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .notification-request__link {
 | |
|     transition: padding-inline-start 0.1s ease-in-out;
 | |
|   }
 | |
| 
 | |
|   &--forced-checkbox {
 | |
|     cursor: pointer;
 | |
| 
 | |
|     &:hover {
 | |
|       background: var(--on-surface-color);
 | |
|     }
 | |
| 
 | |
|     .notification-request__checkbox {
 | |
|       opacity: 1;
 | |
|       width: 30px;
 | |
|     }
 | |
| 
 | |
|     .notification-request__link {
 | |
|       padding-inline-start: 30px;
 | |
|     }
 | |
| 
 | |
|     .notification-request__actions {
 | |
|       display: none;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .more-from-author {
 | |
|   box-sizing: border-box;
 | |
|   font-size: 14px;
 | |
|   color: $darker-text-color;
 | |
|   background: var(--surface-background-color);
 | |
|   border: 1px solid var(--background-border-color);
 | |
|   border-top: 0;
 | |
|   border-radius: 0 0 8px 8px;
 | |
|   padding: 15px;
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   flex-wrap: wrap;
 | |
|   gap: 4px 8px;
 | |
| 
 | |
|   .logo {
 | |
|     width: 16px;
 | |
|     height: 16px;
 | |
|     color: $darker-text-color;
 | |
|   }
 | |
| 
 | |
|   & > span {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     gap: 8px;
 | |
|   }
 | |
| 
 | |
|   a {
 | |
|     display: inline-flex;
 | |
|     align-items: center;
 | |
|     gap: 4px;
 | |
|     font-weight: 500;
 | |
|     color: $primary-text-color;
 | |
|     text-decoration: none;
 | |
| 
 | |
|     &:hover,
 | |
|     &:focus,
 | |
|     &:active {
 | |
|       color: $highlight-text-color;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .notification-group {
 | |
|   display: flex;
 | |
|   align-items: flex-start;
 | |
|   gap: 8px;
 | |
|   padding: 16px 24px;
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
| 
 | |
|   &__icon {
 | |
|     width: 40px;
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     justify-content: center;
 | |
|     flex: 0 0 auto;
 | |
|     color: $dark-text-color;
 | |
| 
 | |
|     .icon {
 | |
|       width: 28px;
 | |
|       height: 28px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &--follow &__icon,
 | |
|   &--follow-request &__icon {
 | |
|     color: $highlight-text-color;
 | |
|   }
 | |
| 
 | |
|   &--favourite &__icon {
 | |
|     color: $gold-star;
 | |
|   }
 | |
| 
 | |
|   &--reblog &__icon {
 | |
|     color: $valid-value-color;
 | |
|   }
 | |
| 
 | |
|   &--relationships-severance-event &__icon,
 | |
|   &--admin-report &__icon,
 | |
|   &--admin-sign-up &__icon {
 | |
|     color: $dark-text-color;
 | |
|   }
 | |
| 
 | |
|   &--moderation-warning &__icon {
 | |
|     color: $red-bookmark;
 | |
|   }
 | |
| 
 | |
|   &--follow-request &__actions {
 | |
|     align-items: center;
 | |
|     display: flex;
 | |
|     gap: 8px;
 | |
| 
 | |
|     .icon-button {
 | |
|       border: 1px solid var(--background-border-color);
 | |
|       border-radius: 50%;
 | |
|       padding: 1px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__main {
 | |
|     display: flex;
 | |
|     flex-direction: column;
 | |
|     gap: 8px;
 | |
|     flex: 1 1 auto;
 | |
|     overflow: hidden;
 | |
|     container-type: inline-size;
 | |
| 
 | |
|     &__header {
 | |
|       display: flex;
 | |
|       flex-direction: column;
 | |
|       gap: 8px;
 | |
| 
 | |
|       &__wrapper {
 | |
|         display: flex;
 | |
|         justify-content: space-between;
 | |
|       }
 | |
| 
 | |
|       &__label {
 | |
|         display: flex;
 | |
|         flex-wrap: wrap;
 | |
|         gap: 2px 8px;
 | |
|         font-size: 15px;
 | |
|         line-height: 22px;
 | |
|         color: $darker-text-color;
 | |
| 
 | |
|         a {
 | |
|           color: inherit;
 | |
|           text-decoration: none;
 | |
|         }
 | |
| 
 | |
|         bdi {
 | |
|           font-weight: 700;
 | |
|           color: $primary-text-color;
 | |
|         }
 | |
| 
 | |
|         time {
 | |
|           color: $dark-text-color;
 | |
|         }
 | |
| 
 | |
|         @container (width < 350px) {
 | |
|           time,
 | |
|           &-separator {
 | |
|             display: none;
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &__status {
 | |
|       border: 1px solid var(--background-border-color);
 | |
|       border-radius: 8px;
 | |
|       padding: 8px;
 | |
|     }
 | |
| 
 | |
|     &__additional-content {
 | |
|       color: $dark-text-color;
 | |
|       margin-top: -8px; // to offset the parent's `gap` property
 | |
|       font-size: 15px;
 | |
|       line-height: 22px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .status {
 | |
|     padding: 0;
 | |
|     border: 0;
 | |
|   }
 | |
| 
 | |
|   &__embedded-status {
 | |
|     display: flex;
 | |
|     flex-direction: column;
 | |
|     gap: 8px;
 | |
|     cursor: pointer;
 | |
| 
 | |
|     &__account {
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       gap: 4px;
 | |
|       color: $dark-text-color;
 | |
|       font-size: 15px;
 | |
|       line-height: 22px;
 | |
| 
 | |
|       bdi {
 | |
|         color: $darker-text-color;
 | |
|       }
 | |
| 
 | |
|       .account__avatar {
 | |
|         flex: 0 0 auto;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &__content {
 | |
|       display: -webkit-box;
 | |
|       font-size: 15px;
 | |
|       line-height: 22px;
 | |
|       color: $darker-text-color;
 | |
|       -webkit-line-clamp: 4;
 | |
|       line-clamp: 4;
 | |
|       -webkit-box-orient: vertical;
 | |
|       max-height: none;
 | |
|       overflow: hidden;
 | |
| 
 | |
|       p,
 | |
|       a {
 | |
|         color: inherit;
 | |
|       }
 | |
| 
 | |
|       p {
 | |
|         margin-bottom: 8px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .reply-indicator__attachments {
 | |
|       margin-top: 0;
 | |
|       font-size: 15px;
 | |
|       line-height: 22px;
 | |
|       color: $dark-text-color;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .notification-group__actions,
 | |
| .compose-form__actions {
 | |
|   .button {
 | |
|     display: block; // Otherwise text-ellipsis doesn't work
 | |
|     flex: 1 1 auto;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .notification-ungrouped {
 | |
|   padding: 16px 24px;
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
| 
 | |
|   &__header {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     gap: 8px;
 | |
|     color: $dark-text-color;
 | |
|     font-size: 15px;
 | |
|     line-height: 22px;
 | |
|     font-weight: 500;
 | |
|     padding-inline-start: 24px;
 | |
|     margin-bottom: 16px;
 | |
| 
 | |
|     &__icon {
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       justify-content: center;
 | |
|       flex: 0 0 auto;
 | |
| 
 | |
|       .icon {
 | |
|         width: 16px;
 | |
|         height: 16px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     a {
 | |
|       color: inherit;
 | |
|       text-decoration: none;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .status {
 | |
|     border: 0;
 | |
|     padding: 0;
 | |
| 
 | |
|     &__avatar {
 | |
|       width: 40px;
 | |
|       height: 40px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .status__wrapper-direct {
 | |
|     background: transparent;
 | |
|   }
 | |
| 
 | |
|   $icon-margin: 48px; // 40px avatar + 8px gap
 | |
| 
 | |
|   .status__content,
 | |
|   .status__action-bar,
 | |
|   .media-gallery,
 | |
|   .video-player,
 | |
|   .audio-player,
 | |
|   .attachment-list,
 | |
|   .picture-in-picture-placeholder,
 | |
|   .more-from-author,
 | |
|   .status-card,
 | |
|   .hashtag-bar,
 | |
|   .content-warning,
 | |
|   .filter-warning {
 | |
|     margin-inline-start: $icon-margin;
 | |
|     width: calc(100% - $icon-margin);
 | |
|   }
 | |
| 
 | |
|   .more-from-author {
 | |
|     width: calc(100% - $icon-margin + 2px);
 | |
|   }
 | |
| 
 | |
|   .status__content__read-more-button {
 | |
|     margin-inline-start: $icon-margin;
 | |
|   }
 | |
| 
 | |
|   .notification__report {
 | |
|     border: 0;
 | |
|     padding: 0;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .notification-group--unread,
 | |
| .notification-ungrouped--unread {
 | |
|   position: relative;
 | |
| 
 | |
|   &::before {
 | |
|     content: '';
 | |
|     position: absolute;
 | |
|     top: 0;
 | |
|     inset-inline-start: 0;
 | |
|     width: 100%;
 | |
|     height: 100%;
 | |
|     border-inline-start: 4px solid $highlight-text-color;
 | |
|     pointer-events: none;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .hover-card-controller[data-popper-reference-hidden='true'] {
 | |
|   opacity: 0;
 | |
|   pointer-events: none;
 | |
| }
 | |
| 
 | |
| .hover-card {
 | |
|   box-shadow: var(--dropdown-shadow);
 | |
|   background: var(--modal-background-color);
 | |
|   backdrop-filter: var(--background-filter);
 | |
|   border: 1px solid var(--modal-border-color);
 | |
|   border-radius: 8px;
 | |
|   padding: 16px;
 | |
|   width: 270px;
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
|   gap: 12px;
 | |
| 
 | |
|   &--loading {
 | |
|     position: relative;
 | |
|     min-height: 100px;
 | |
|   }
 | |
| 
 | |
|   &__name {
 | |
|     display: flex;
 | |
|     gap: 12px;
 | |
|     text-decoration: none;
 | |
|     color: inherit;
 | |
|   }
 | |
| 
 | |
|   &__numbers,
 | |
|   &__familiar-followers {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     flex-wrap: wrap;
 | |
|     gap: 2px 10px;
 | |
|   }
 | |
| 
 | |
|   &__numbers {
 | |
|     font-size: 15px;
 | |
|     line-height: 22px;
 | |
|     color: $secondary-text-color;
 | |
| 
 | |
|     strong {
 | |
|       font-weight: 700;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__text-row {
 | |
|     display: flex;
 | |
|     flex-direction: column;
 | |
|     gap: 8px;
 | |
|   }
 | |
| 
 | |
|   &__bio {
 | |
|     color: $secondary-text-color;
 | |
|     font-size: 14px;
 | |
|     line-height: 20px;
 | |
|     display: -webkit-box;
 | |
|     -webkit-line-clamp: 2;
 | |
|     -webkit-box-orient: vertical;
 | |
|     max-height: 2 * 20px;
 | |
|     overflow: hidden;
 | |
| 
 | |
|     p {
 | |
|       margin-bottom: 0;
 | |
|     }
 | |
| 
 | |
|     a {
 | |
|       color: inherit;
 | |
|       text-decoration: underline;
 | |
| 
 | |
|       &:hover,
 | |
|       &:focus,
 | |
|       &:active {
 | |
|         text-decoration: none;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__note {
 | |
|     &-label {
 | |
|       color: $dark-text-color;
 | |
|       font-size: 12px;
 | |
|       font-weight: 500;
 | |
|       text-transform: uppercase;
 | |
|     }
 | |
| 
 | |
|     dd {
 | |
|       white-space: pre-line;
 | |
|       color: $secondary-text-color;
 | |
|       overflow: hidden;
 | |
|       line-clamp: 3; // Not yet supported in browers
 | |
|       display: -webkit-box; // The next 3 properties are needed
 | |
|       -webkit-line-clamp: 3;
 | |
|       -webkit-box-orient: vertical;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .display-name {
 | |
|     font-size: 15px;
 | |
|     line-height: 22px;
 | |
| 
 | |
|     bdi {
 | |
|       font-weight: 500;
 | |
|       color: $primary-text-color;
 | |
|     }
 | |
| 
 | |
|     &__account {
 | |
|       display: block;
 | |
|       color: $dark-text-color;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .account-fields {
 | |
|     color: $secondary-text-color;
 | |
|     font-size: 14px;
 | |
|     line-height: 20px;
 | |
| 
 | |
|     a {
 | |
|       color: inherit;
 | |
|       text-decoration: none;
 | |
| 
 | |
|       &:focus,
 | |
|       &:hover,
 | |
|       &:active {
 | |
|         text-decoration: underline;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     dl {
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       gap: 4px;
 | |
| 
 | |
|       dt {
 | |
|         flex: 0 1 auto;
 | |
|         color: $dark-text-color;
 | |
|         min-width: 0;
 | |
|         overflow: hidden;
 | |
|         white-space: nowrap;
 | |
|         text-overflow: ellipsis;
 | |
|       }
 | |
| 
 | |
|       dd {
 | |
|         flex: 1 1 auto;
 | |
|         font-weight: 500;
 | |
|         min-width: 0;
 | |
|         overflow: hidden;
 | |
|         white-space: nowrap;
 | |
|         text-overflow: ellipsis;
 | |
|         text-align: end;
 | |
|       }
 | |
| 
 | |
|       &.verified {
 | |
|         dd {
 | |
|           display: flex;
 | |
|           align-items: center;
 | |
|           justify-content: flex-end;
 | |
|           gap: 4px;
 | |
|           overflow: hidden;
 | |
|           white-space: nowrap;
 | |
|           color: $valid-value-color;
 | |
| 
 | |
|           & > span {
 | |
|             overflow: hidden;
 | |
|             text-overflow: ellipsis;
 | |
|           }
 | |
| 
 | |
|           a {
 | |
|             font-weight: 500;
 | |
|           }
 | |
| 
 | |
|           .icon {
 | |
|             width: 16px;
 | |
|             height: 16px;
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .content-warning {
 | |
|   display: block;
 | |
|   box-sizing: border-box;
 | |
|   background: var(--nested-card-background);
 | |
|   color: var(--nested-card-text);
 | |
|   border: var(--nested-card-border);
 | |
|   border-radius: 8px;
 | |
|   padding: 8px (5px + 8px);
 | |
|   position: relative;
 | |
|   font-size: 15px;
 | |
|   line-height: 22px;
 | |
|   cursor: pointer;
 | |
| 
 | |
|   p {
 | |
|     margin-bottom: 8px;
 | |
|     font-weight: 500;
 | |
|   }
 | |
| 
 | |
|   .link-button {
 | |
|     font-size: inherit;
 | |
|     line-height: inherit;
 | |
|     font-weight: 500;
 | |
|   }
 | |
| 
 | |
|   &--filter {
 | |
|     color: $darker-text-color;
 | |
| 
 | |
|     p {
 | |
|       font-weight: normal;
 | |
|     }
 | |
| 
 | |
|     .filter-name {
 | |
|       font-weight: 500;
 | |
|       color: $secondary-text-color;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .lists__item {
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   gap: 16px;
 | |
|   padding-inline-end: 13px;
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
| 
 | |
|   &__title {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     gap: 5px;
 | |
|     padding: 16px 13px;
 | |
|     flex: 1 1 auto;
 | |
|     font-size: 16px;
 | |
|     line-height: 24px;
 | |
|     color: $secondary-text-color;
 | |
|     text-decoration: none;
 | |
| 
 | |
|     &:is(a):hover,
 | |
|     &:is(a):focus,
 | |
|     &:is(a):active {
 | |
|       color: $primary-text-color;
 | |
|     }
 | |
| 
 | |
|     input {
 | |
|       display: block;
 | |
|       width: 100%;
 | |
|       background: transparent;
 | |
|       border: 0;
 | |
|       padding: 0;
 | |
|       font-family: inherit;
 | |
|       font-size: inherit;
 | |
|       line-height: inherit;
 | |
|       color: inherit;
 | |
| 
 | |
|       &::placeholder {
 | |
|         color: var(--input-placeholder-color);
 | |
|         opacity: 1;
 | |
|       }
 | |
| 
 | |
|       &:focus {
 | |
|         outline: 0;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .column-search-header {
 | |
|   display: flex;
 | |
|   gap: 12px;
 | |
|   align-items: center;
 | |
|   border: 1px solid var(--background-border-color);
 | |
|   border-top: 0;
 | |
|   border-bottom: 0;
 | |
|   padding: 16px;
 | |
|   padding-bottom: 8px;
 | |
| 
 | |
|   input {
 | |
|     background: var(--input-background-color);
 | |
|     border: 1px solid var(--background-border-color);
 | |
|     color: var(--on-input-color);
 | |
|     padding: 12px;
 | |
|     font-size: 16px;
 | |
|     line-height: normal;
 | |
|     border-radius: 4px;
 | |
|     display: block;
 | |
|     flex: 1 1 auto;
 | |
| 
 | |
|     &::placeholder {
 | |
|       color: var(--input-placeholder-color);
 | |
|       opacity: 1;
 | |
|     }
 | |
| 
 | |
|     &:focus {
 | |
|       outline: 0;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .column-footer {
 | |
|   padding: 16px;
 | |
| }
 | |
| 
 | |
| .lists-scrollable {
 | |
|   min-height: 50vh;
 | |
| }
 | |
| 
 | |
| .featured-carousel {
 | |
|   background: var(--surface-background-color);
 | |
|   overflow: hidden;
 | |
|   flex-shrink: 0;
 | |
|   border-bottom: 1px solid var(--background-border-color);
 | |
|   touch-action: pan-y;
 | |
| 
 | |
|   &__slides {
 | |
|     display: flex;
 | |
|     flex-wrap: nowrap;
 | |
|     align-items: start;
 | |
|   }
 | |
| 
 | |
|   &__slide {
 | |
|     flex: 0 0 auto;
 | |
|     flex-basis: 100%;
 | |
|     width: 100%;
 | |
|     overflow: hidden;
 | |
|   }
 | |
| 
 | |
|   .status {
 | |
|     border-bottom: 0;
 | |
|   }
 | |
| 
 | |
|   &__header {
 | |
|     padding: 8px 16px;
 | |
|     color: $darker-text-color;
 | |
|     inset-inline-end: 0;
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     gap: 4px;
 | |
|   }
 | |
| 
 | |
|   &__title {
 | |
|     flex-grow: 1;
 | |
|     font-size: 12px;
 | |
|     font-weight: 500;
 | |
|     text-transform: uppercase;
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     gap: 4px;
 | |
| 
 | |
|     .icon {
 | |
|       width: 16px;
 | |
|       height: 16px;
 | |
|     }
 | |
|   }
 | |
| }
 |