$corner-radius: 2px;


/* GLOBALS */
$font-size: 11;
$_bubble_bg_color: $osd_bg_color;
$_bubble_fg_color: $fg_color;
$_bubble_borders_color: $fg_color;
$_bubble_transparent: transparentize($osd_bg_color, 0.17);
$topbar_bg_color: transparentize($main_dark, 0.05);

stage {
  @include fontsize($font-size);
  color: $fg_color;
}

/* WIDGETS */

/* Buttons */
.button, %button {
  @include button(normal);
  border-radius: 5px;
  padding: 4px 32px;
  &:focus { @include button(focus); }
  &:insensitive { @include button(insensitive); }
  &:active { @include button(active); }
  &:hover {
    @include button(hover);
  }
}

.modal-dialog-linked-button {
  padding: 10px;
  @include button(normal);
  &:insensitive { @include button(insensitive); }
  &:active {
    @include button(active);
  }
  &:focus {
    @include button(focus);
    &:hover {
      @include button(focus);
    }
  }
  &:hover {
    @include button(hover);
  }

  &:first-child { border-radius: 0px 0px 0px 10px; }
  &:last-child { border-radius: 0px 0px 10px 0px; }
  &:first-child:last-child { border-radius: 0px 0px 10px 10px; }
}

/* Entries */
StEntry {
  @include entry(normal);
  border-radius: 6px;
  padding: 4px;
  color: $fg_color;
  border-width: 1px;
  &:hover { @include entry(hover);}
  &:focus { @include entry(focus,$fc:transparentize($fg_color,0.5));}
  &:insensitive { @include entry(insensitive);}
  selection-background-color: $selected_bg_color;
  selected-color: $selected_fg_color;
  StIcon.capslock-warning {
    icon-size: 16px;
    warning-color: $warning_color;
    padding: 0 4px;
  }

  StLabel.hint-text { color: transparentize($fg_color, 0.3); }

}


/* Scrollbars */

StScrollView {
  &.vfade { -st-vfade-offset: 68px; }
  &.hfade { -st-hfade-offset: 68px; }
}

StScrollBar {
  padding: 0;

  StScrollView & {
    min-width: 14px;
    min-height: 14px;
  }

  StBin#trough {
    border-radius: 0;
    background-color: transparent;
  }

  StButton#vhandle, StButton#hhandle {
    border-radius: 8px;
    background-color: mix($fg_color, $bg_color, 20%);
    //border: 3px solid transparent; //would be nice to margin or at least to transparent
    margin: 3px;
    &:hover { background-color: mix($fg_color, $bg_color, 80%); }
    &:active { background-color: $selected_bg_color; }
  }
}

/* Slider */

.slider {
  height: 1em;
  color: $fg_color;
  border-color: black;
  box-shadow: none;
  -slider-height: 0.1em;
  -slider-background-color: $gray; //background of the trough
  -slider-border-color: black; //trough border color
  -slider-active-background-color: $teal; //active trough fill
  -slider-active-border-color: $lime; //active trough border
  -slider-border-width: 0;
  -slider-handle-radius: 6px;
  -slider-handle-border-width: 1px;
  -slider-handle-border-color: $fg_color; // because 0 width

  -barlevel-height: 0.2em;
  -barlevel-background-color: $gray;
  -barlevel-border-color: black;
  -barlevel-active-background-color: $teal;
  -barlevel-active-border-color: $lime;
  -barlevel-border-width: 0;
  -barlevel-handle-radius: 6px; 
  -barlevel-overdrive-color: $teal;
  -barlevel-overdrive-border-color: transparent;
  -barlevel-overdrive-separator-width: 0px;
}

/* Check Boxes */

.check-box {
  StBoxLayout { spacing: .8em; }
  StBin {
    width: 24px;
    height: 22px;
    background-image: url("assets/checkbox-off.svg");
  }
  &:focus, &:hover StBin { background-image: url("assets/checkbox-off-focused.svg"); }
  &:checked StBin { background-image: url("assets/checkbox.svg"); }
  &:focus:checked StBin { background-image: url("assets/checkbox-focused.svg"); }
}

/* Switches */
.toggle-switch {
  width: 65px;
  height: 22px;
  background-size: contain;
  //Gnome 3.32//
  background-image: url("assets/toggle-off.svg");
  &:checked { background-image: url("assets/toggle-on.svg"); }
}

  @each $v in us, intl {
    .toggle-switch-#{$v} {
      background-image: url("assets/toggle-off.svg");
      &:checked { background-image: url("assets/toggle-on.svg"); }
    }
  }

/* links */
.shell-link {
  color: $link_color;
  &:hover { color: lighten($link_color,10%); }
}

/* Modal Dialogs */

.headline { font-size: 110%; }
.lightbox { background-color: black; }
.flashspot { background-color: white; }

.modal-dialog {
  border: 1px solid $borders_color;
  border-radius: 10px;
  color: $osd_fg_color;
  background-color: darken($osd_bg_color,5%);
  box-shadow: $depth6;

  .modal-dialog-content-box { padding: 24px; }
  .run-dialog-entry {
    width: 20em;
    margin-bottom: 6px;
  }
  .run-dialog-error-box {
    color: $error_color;
    padding-top: 16px;
    spacing: 6px;
  }
  .run-dialog-button-box { padding-top: 1em; }
  .run-dialog-label {
    @include fontsize($font-size + 1.1);
    font-weight: bold;
    color: darken($osd_fg_color,10%);
    padding-bottom: .4em;
  }

  .run-dialog-description {
    color: $fg_color;
  }

}

  .mount-dialog-subject,
  .end-session-dialog-subject { //this should be a generic header class
    @include fontsize($font-size * 1.3);
  }

/* Message Dialog */
  .message-dialog-main-layout {
    padding: 12px 20px 0;
    spacing: 12px;
  }

  .message-dialog-content {
    max-width: 28em;
    spacing: 20px;
  }

  .message-dialog-icon {
    min-width: 48px;
    icon-size: 48px;
  }

  .message-dialog-title {
    font-weight: bold;
  }

  .message-dialog-subtitle {
    color: darken($fg_color,40%);
    font-weight: bold;
  }

/* End Session Dialog */
.end-session-dialog {
  spacing: 42px;
  border: none;
  & .modal-dialog-linked-button:last-child {
    background-color: $red;
    color: #fff;
    &:hover, &:focus {
      background: darken($error_color, 3%);
      color: #fff;
    }
  }
}

  .end-session-dialog-list {
      padding-top: 20px;
  }

  .end-session-dialog-layout {
    padding-left: 17px;
    &:rtl { padding-right: 17px; }
  }

  .end-session-dialog-description {
    width: 28em;
    padding-bottom: 10px;
    &:rtl {
      text-align: right;
    }
  }

  .end-session-dialog-warning {
    width: 28em;
    color: $warning_color;
    padding-top: 6px;
    &:rtl {
      text-align: right;
    }
  }

  .end-session-dialog-logout-icon {
    //border: 2px solid #8b8b8b;
    border-radius: 3px;
    width: 48px;
    height: 48px;
    background-size: contain;
  }

  .end-session-dialog-shutdown-icon {
    color: $error_color;
    width: 48px;
    height: 48px;
  }

  .end-session-dialog-inhibitor-layout {
    spacing: 16px;
    max-height: 200px;
    padding-right: 65px;
    padding-left: 65px;
  }

  .end-session-dialog-session-list,
  .end-session-dialog-app-list {
    spacing: 1em;
  }

  .end-session-dialog-list-header {
    font-weight: bold;
    &:rtl { text-align: right; }
  }

  .end-session-dialog-app-list-item,
  .end-session-dialog-session-list-item {
    spacing: 1em;
  }

  .end-session-dialog-app-list-item-name,
  .end-session-dialog-session-list-item-name {
    font-weight: bold;
  }

  .end-session-dialog-app-list-item-description {
    color: darken($fg_color,5%);
    font-size: 10pt;
  }

/* ShellMountOperation Dialogs */
.shell-mount-operation-icon { icon-size: 48px; }

  .mount-dialog {
    spacing: 24px;

    .message-dialog-title {
      padding-top: 10px;
      padding-left: 17px;
      padding-bottom: 6px;
      max-width: 34em;
    }

    .message-dialog-title:rtl {
      padding-left: 0px;
      padding-right: 17px;
    }

    .message-dialog-body {
      padding-left: 17px;
      width: 28em;
    }

    .message-dialog-body:rtl {
      padding-left: 0px;
      padding-right: 17px;
    }
  }

  .mount-dialog-app-list {
    max-height: 200px;
    padding-top: 24px;
    padding-left: 49px;
    padding-right: 32px;
  }

  .mount-dialog-app-list:rtl {
    padding-right: 49px;
    padding-left: 32px;
  }

  .mount-dialog-app-list-item {
    color: darken($fg_color,10%);
    &:hover { color: $fg_color; }
    &:ltr { padding-right: 1em; }
    &:rtl { padding-left: 1em; }
  }

  .mount-dialog-app-list-item-icon {
    &:ltr { padding-right: 17px; }
    &:rtl { padding-left: 17px; }
  }

  .mount-dialog-app-list-item-name {
    font-size: 10pt;
  }


/* Password or Authentication Dialog */

.prompt-dialog {
  //this is the width of the entire modal popup
  width: 34em;
  border: none;
  border-radius: 10px;

  .message-dialog-main-layout { spacing: 24px; padding: 10px; }
  .message-dialog-content { spacing: 16px; }
  .message-dialog-title { color: darken($osd_fg_color,25%); }
}

  .prompt-dialog-description:rtl {
    text-align: right;
  }

  .prompt-dialog-password-box {
    spacing: 1em;
    padding-bottom: 1em;
  }

  .prompt-dialog-error-label {
    font-size: 10pt;
    color: $error_color;
    padding-bottom: 8px;
  }

  .prompt-dialog-info-label {
    font-size: 10pt;
    padding-bottom: 8px;
  }

  .hidden {
    color: rgba(0,0,0,0);
  }

  .prompt-dialog-null-label {
    font-size: 10pt;
    padding-bottom: 8px;
  }


/* Polkit Dialog */

.polkit-dialog-user-layout {
  padding-left: 10px;
  spacing: 10px;
  &:rtl {
    padding-left: 0px;
    padding-right: 10px;
  }
}

  .polkit-dialog-user-root-label {
    color: $warning_color;
  }

  .polkit-dialog-user-icon {
    border-radius: 3px;
    background-size: contain;
    width: 48px;
    height: 48px;
  }

/* Audio selection dialog */
.audio-device-selection-dialog {
  spacing: 30px;
}

  .audio-selection-content {
    spacing: 20px;
    padding: 24px;
  }

  .audio-selection-title {
    font-weight: bold;
    text-align: center;
  }

  .audio-selection-box {
    spacing: 20px;
  }

  .audio-selection-device {
    border: 1px solid $_bubble_borders_color;
    border-radius: 12px;
    &:active,&:hover,&:focus { background-color: $selected_bg_color; }
  }

  .audio-selection-device-box {
    padding: 20px;
    spacing: 20px;
  }

  .audio-selection-device-icon {
    icon-size: 64px;
  }

/* Access Dialog */
.access-dialog {
  spacing: 30px;
}

/* Geolocation Dialog */
.geolocation-dialog {
  spacing: 30px;
}

/* Extension Dialog */
.extension-dialog {
  .message-dialog-main-layout { spacing: 24px; padding: 10px; }
  .message-dialog-title { color: darken($osd_fg_color,25%); }
}

/* Inhibit-Shortcuts Dialog */
.inhibit-shortcuts-dialog {
  spacing: 30px;
}

/* Network Agent Dialog */

.network-dialog-secret-table {
  spacing-rows: 15px;
  spacing-columns: 1em;
}

.keyring-dialog-control-table {
  spacing-rows: 15px;
  spacing-columns: 1em;
}

/* Popovers/Menus */

.popup-menu {
  min-width: 15em;
  background-color: transparent;
  color: $fg_color;

  //.popup-status-menu-item { font-weight: normal;  color: pink; } //dunno what that is
  &.panel-menu {
    -boxpointer-gap: 4px;
    margin-bottom: 1.75em;
  }
}

.popup-menu-arrow { } //defined globally in the TOP BAR
.popup-sub-menu {
  background-color: lighten($bg_color, 2%);
  box-shadow: $depth6;
  border: none;
  border-radius: 0px 0px 6px 6px;
  .popup-menu-item {
    border-radius: 0;
    margin: 0;

    &:last-child {
      border-radius: 0 0 6px 6px;
    }

    &:active,
    &.selected,
    &:hover,
    &:focus { background-color: lighten($bg_color, 9%) !important; color: $fg_color; }
  }

}

.popup-menu-content { 
  padding: 6px; 
  background: $main_dark;
  border-radius: 12px;
  border: 1px solid $borders_color;
}

.popup-menu-item {
  spacing: 6px;
  border-radius: 6px;
  background-gradient-direction: none;

  &:ltr {padding-left: 6px;}
  &:rtl {padding-right: 6px;}

  &:active,
  &.selected,
  &:hover,
  &:focus { background-color: lighten($bg_color, 3%) !important; color: $fg_color !important; }

  &:checked { 
    background-color: lighten($bg_color, 7%) !important;
    border-radius: 6px 6px 0px 0px;
    box-shadow: none;
    color: $selected_fg_color !important;
  }
  
  &:insensitive { color: transparentize($fg_color,.5); }
}

.popup-inactive-menu-item { //all icons and other graphical elements
  color: $fg_color;

  &:insensitive { color: transparentize($fg_color,0.5); }
}

// symbolic icons in popover
.popup-menu-arrow,
.popup-menu-icon {
  icon-size: 16px !important; // for some reason the variable doesn't work here
}


.popup-menu-ornament {
  text-align: right;
  width: 1.2em;
}

// separator
.popup-separator-menu-item {
  margin: 6px 0;
  padding:0 !important;
  &:ltr { margin-right: 6px;}
  &:rtl { margin-left: 6px;}

  .popup-separator-menu-item-separator {
    height: 1px; //not really the whole box
    background-color: $gray;
  }

  .popup-menu-ornament {
    width: 0 !important;
  }

  // separators in submenus
  .popup-sub-menu & {
    background-color: transparent;

    // account for ornament
    &:ltr { margin-right: 2.5em;}
    &:rtl { margin-left: 2.5em;}

    .popup-separator-menu-item-separator {
      background-color: lighten($gray, 7%);
    }
  }
}


// Background menu
.background-menu { -boxpointer-gap: 4px; -arrow-rise: 0px; }

/* fallback menu
- odd thing for styling App menu when apparently not running under shell. Light Adwaita styled
  app menu inside the main app window itself rather than the top bar
*/


/* OSD */
.osd-window {
  text-align: center;
  font-weight: bold;
  spacing: 1em;
  margin: 32px;
  min-width: 64px;
  min-height: 64px;

  .osd-monitor-label { font-size: 3em; }
  .level {
    height: 0.4em;
    border-radius: 0.3em;
    color: $osd_fg_color;
    border: 1px solid $borders_color;

    -barlevel-height: 0.4em;
    -barlevel-background-color: $gray;
    -barlevel-active-background-color: $selected_bg_color;
    -barlevel-overdrive-color: $red;
    -barlevel-overdrive-separator-width: 0.2em; 
  }
  .level-bar {
    background-color: $selected_bg_color;
    border-radius: 0.3em;
  }
}

/* Pad OSD */
.pad-osd-window {
    padding: 32px;
    background-color: transparentize(black, 0.2);

  .pad-osd-title-box { spacing: 12px; }
  .pad-osd-title-menu-box { spacing: 6px; }
}

.combo-box-label {
    width: 15em;
}

/* App Switcher */
.switcher-popup {
  padding: 8px;
  spacing: 16px;
}

.osd-window,
.resize-popup,
.switcher-list {
  @extend %osd-panel;
}

  .switcher-list-item-container { spacing: 8px;  }

  .switcher-list .item-box {
    padding: 8px;
    border-radius: 4px;
  }

  .switcher-list .item-box:outlined {
    padding: 6px;
    border: 2px solid darken($borders_color,10%);
  }

  .switcher-list .item-box:selected {
    background-color: $selected_bg_color;
    color: $selected_fg_color;
  }

  .switcher-list .thumbnail-box {
    padding: 2px;
    spacing: 4px;
  }

  .switcher-list .thumbnail {
    width:  256px;
  }

  .switcher-list .separator {
    width: 1px;
    background: $borders_color;
  }

  .switcher-arrow {
    border-color: rgba(0,0,0,0);
    color: transparentize($fg_color,0.2);
    &:highlighted {
      color: $fg_color;
    }
  }

  .input-source-switcher-symbol {
    font-size: 34pt;
    width: 96px;
    height: 96px;
  }

/* Window Cycler */
.cycler-highlight { border: 5px solid $selected_bg_color; }

/* Workspace Switcher */
.workspace-switcher-group { padding: 12px; }

  .workspace-switcher-container {
    @extend %osd-panel;
  }

  .workspace-switcher {
    background: transparent;
    border: 0px;
    border-radius: 0px;
    padding: 0px;
    spacing: 8px;
  }

  .ws-switcher-active-up,
  .ws-switcher-active-down,
  .ws-switcher-active-left,
  .ws-switcher-active-right {
    height: 50px;
    background-color: $selected_bg_color;
    color: $selected_fg_color;
    border: none;
    background-size: 32px;
    border-radius: 8px;
  }
  .ws-switcher-active-up {
    background-image: url("assets/ws-switch-arrow-up.png"); }

  .ws-switcher-active-down {
    background-image: url("assets/ws-switch-arrow-down.png"); }

  .ws-switcher-box {
    height: 50px;
    border: 1px solid transparentize($osd_fg_color,0.9);
    background: darken($_bubble_bg_color, 10%);
    border-radius: 8px;
  }

%osd-panel {
  color: $_bubble_fg_color;
  background-color: $_bubble_bg_color;
  border: 1px solid $borders_color;
  box-shadow: 0px 0px 7px $borders_color;
  border-radius: 5px;
  padding: 12px;
}

/* Tiled window previews */
.tile-preview {
  background-color: transparentize($selected_bg_color, 0.2);
  border: 1px solid $selected_bg_color;
}

  .tile-preview-left.on-primary {
    border-radius: $corner-radius $corner-radius 0 0;
  }

  .tile-preview-right.on-primary {
    border-radius: 0 $corner-radius 0 0;
  }

  .tile-preview-left.tile-preview-right.on-primary {
    border-radius: $corner-radius $corner-radius 0 0;
  }

/* TOP BAR */

#panel {
  background-gradient-direction: none;
  background-color: $topbar_bg_color;
  /* transition from solid to transparent */
  transition-duration: 500ms;
  font-weight: bold;
  height: 2.1em;
  padding: 0px 0px;

  &.unlock-screen,
  &.login-screen,
  &.lock-screen {
    background-color: transparent;
  }

  #panelLeft, #panelCenter { // spacing between activities<>app menu and such
    spacing: 4px;
  }

  .panel-corner {
    -panel-corner-radius: 0px;
    -panel-corner-background-color: rgba(0, 0, 0, 0.2);
    -panel-corner-border-width: 2px;
    -panel-corner-border-color: transparent;

    &:active, &:overview, &:focus {
      -panel-corner-border-color: lighten($selected_bg_color,5%);
    }

    &.lock-screen, &.login-screen, &.unlock-screen {
      -panel-corner-radius: 0;
      -panel-corner-background-color: transparent;
      -panel-corner-border-color: transparent;
    }
  }

  .panel-button {
    -natural-hpadding: 12px;
    -minimum-hpadding: 6px;
    font-weight: bold;
    color: $topbar_color;
    transition-duration: 100ms;

    .app-menu-icon {
      -st-icon-style: symbolic;
      margin-left: 4px;
      margin-right: 4px;
      //dimensions of the icon are hardcoded
    }

    .system-status-icon,
    .app-menu-icon > StIcon,
    .popup-menu-arrow {
      icon-shadow: none;
    }

    &:hover {
      box-shadow: inset 0 0 0 100px lighten($topbar_bg_color, 10%);
      color: lighten($topbar_color, 10%);
      transition-duration: 200ms;

      &.clock-display {
        box-shadow: none;

        .clock {
          box-shadow: inset 0 0 0 100px lighten($topbar_bg_color, 10%);
        }
      }
    }

    &:active, &:overview, &:focus, &:checked {
      // Trick due to St limitations. It needs a background to draw
      // a box-shadow
      box-shadow: inset 0 0 0 100px $selected_bg_color;
      color: $selected_fg_color;
      transition-duration: 200ms;

      &.clock-display {
        box-shadow: none;

        .clock {
          box-shadow: inset 0 0 0 100px $selected_bg_color;
        }
      }
    }

    .system-status-icon { icon-size: 1.09em; padding: 0 5px; }
    .unlock-screen &,
    .login-screen &,
    .lock-screen & {
      color: lighten($fg_color, 10%);
      &:focus, &:hover, &:active { color: lighten($fg_color, 10%); }
    }

  }

  .panel-status-indicators-box,
  .panel-status-menu-box {
    spacing: 2px;
  }

  // spacing between power icon and (optional) percentage label
  .power-status.panel-status-indicators-box {
    spacing: 0;
  }

  .screencast-indicator { color: $warning_color; }

  &.solid {
    background-color: $dracula;
    /* transition from transparent to solid */
    transition-duration: 300ms;

    .panel-corner {
      -panel-corner-background-color: black;
    }
    .system-status-icon,
    .app-menu-icon > StIcon,
    .popup-menu-arrow {
      icon-shadow: none;
    }
  }
}

  .calendar {
    background: transparent;
    border: none;
    box-shadow: none;
  }

  .world-clocks-button, .weather-button, .events-button {
    background: darken($bg_color, 0.7%);
    border-radius: 7px;
    box-shadow: 0px 0px 1px 1px $borders_color inset;
    color: $fg_color;
  }

    .datemenu-calendar-column {
      border: none;
    }

    .datemenu-today-button,
    .events-section-title,
    .message-list-section-title{
      border-radius: 4px;
      color: $fg_color;
      padding: .4em;
    }


    .datemenu-today-button,
    .world-clocks-button,
    .weather-button,
    .events-section-title,
    .message-list-section-title,
    .events-button {
      &:hover,&:focus { background-color: lighten($bg_color,5%); }
      &:active {
        color: lighten($selected_fg_color,5%);
        background-color: $selected_bg_color;
      }
    }

    .datemenu-today-button .day-label {
    }

    .datemenu-today-button .date-label {
      font-size: 1.5em;
    }

    .world-clocks-header,
    .weather-header,
    .events-section-title,
    .message-list-section-title,
    .events-title {
      color: darken($fg_color, 10%);
      font-weight: bold;
    }

    .events-button .event-time {
      color: darken($fg_color, 4%);
    }

    .world-clocks-grid {
      spacing-rows: 0.4em;
    }

    .weather-box {
      spacing: 0.4em;
    }

    .calendar-month-label {
      color: darken($fg_color,5%);
      font-weight: bold;
      padding: 8px 0;
      &:focus {}
    }

    .pager-button {
      color: white;
      background-color: transparent;
      width: 32px;
      border-radius: 4px;
      &:hover, &:focus { background-color: transparentize($fg_color,0.95); }
      &:active { background-color: transparentize($bg_color,0.95); }
    }

    .calendar-change-month-back { //arrow back
      background-image: url("assets/calendar-arrow-left.svg");
      &:rtl { background-image: url("assets/calendar-arrow-right.svg"); }
    }
    .calendar-change-month-forward { //arrow foreward
      background-image: url("assets/calendar-arrow-right.svg");
      &:rtl { background-image: url("assets/calendar-arrow-left.svg"); }
    }

    .calendar-change-month-back StIcon,
    .calendar-change-month-forward StIcon {
      color: darken($fg_color, 5%);
    }

    .calendar-day-base {
      font-size: 80%;
      text-align: center;
      width: 2.4em; height: 2.4em;
      padding: 0.1em;
      margin: 2px;
      border-radius: 99px;
      color: $fg_color;
      background-gradient-direction: none;
      
      &:hover,&:focus { 
        background-color: lighten($bg_color, 7%); 
        box-shadow: none;
      }
      &:active,&:selected {
        color: lighten($selected_fg_color,5%);
        background-color: $selected_bg_color;
        border-color: transparent; //avoid jumparound due to today
        box-shadow: none;
      }
      &.calendar-day-heading {  //day of week heading
        color: $fg_color;
        margin-top: 1em;
        font-size: 70%;
      }
    }
      .calendar-day { //border collapse hack - see calendar.js
        border-width: 0;
      }
      .calendar-day-top { border-top-width: 1px; }
      .calendar-day-left { border-left-width: 1px; }
      .calendar-work-day {

      }
      .calendar-nonwork-day {
        color: $insensitive_fg_color;
      }

      // Today
      .calendar-today {
        font-weight: bold;
        border: 1px solid $selected_bg_color;
        background-color: transparent;
        color: $selected_fg_color !important;

        &:hover,&:focus {
          background-color:lighten($selected_bg_color, 3%);
          color: $selected_fg_color;
        }

        &:active,&:selected {
          background-color: $selected_bg_color;
          color: $selected_fg_color;

          &:hover,&:focus {
            background-color:lighten($selected_bg_color, 3%);
            color: $selected_fg_color;
          }
        }
      }
      .calendar-day-with-events {
        color: lighten($fg_color,10%);
        font-weight: bold;
        background-image: url("assets/calendar-today.svg");
      }
      .calendar-other-month-day {
        color: $insensitive_fg_color;
        opacity: 0.5;
      }
      .calendar-week-number {
        font-size: 70%;
        font-weight: bold;
        width: 2.3em; height: 1.8em;
        border-radius: 2px;
        padding: 0.5em 0 0;
        margin: 6px;
        background-color: transparentize($fg_color,0.7);
        color: $bg_color;
      }

      /* Message list */
      .message-list {
        border-color: $gray;
        .message-title, .message-content, .message-body {
          color: darken($fg_color, 2%);
        }
      }

        .message-list-sections {
          spacing: 1em;
        }

        .message-list-section,
        .message-list-section-list {
          spacing: 0.4em;
        }
        .message-list-section-close{
          & > StIcon {
            icon-size: 16px;
            border-radius: 16px;
            padding: 8px;
            color: $fg_color;
            background-color: transparent;
          }
          &:hover > StIcon,
          &:focus > StIcon
          &:active > StIcon{
            color: $selected_fg_color;
            background: transparent;
          }
        }

        .message {
          &:hover,&:focus { 
            background-color: lighten($base_color, 4%);
          }
          background: $base_color;
          border: 1px solid $borders_color;
          border-radius: 8px; 
          box-shadow: none;
        }

        .message-close-button {
          color: $fg_color;
          &:hover > StIcon,
          &:focus > StIcon
          &:active > StIcon{
            color: $selected_fg_color;
            background: transparent;
          }
        }
          .message-secondary-bin > .event-time {
            color: darken($fg_color, 15%);
            font-size: 0.7em;
            /* HACK: the label should be baseline-aligned with a 1em label,
                     fake this with some bottom padding */
            padding-bottom: 0.13em;
           
          }

          .message-secondary-bin > StIcon {
            icon-size: 16px;
          }

          .message-title {
            //color: darken($fg_color,5%);
            
          }

          .message-content {
          //  color: darken($fg_color,20%);
            padding: 10px;
          }

/* Media Controls */
.message-media-control {

  color: $fg_color;

  // colors are lightened since the media controls are in a card
  &:hover {
    background-color: lighten($base_color, 8%);
    color: $selected_fg_color;
  }

  &:active { 
    background-color: lighten($base_color, 12%);
    color: $selected_fg_color;
  }

  &:insensitive { color: lighten($insensitive_fg_color, 5%); }
  
}
          .media-message-cover-icon {
            icon-size: 48px !important;
            &.fallback {
              color: lighten($bg_color,10%);
              background-color: $bg_color;
              border: 2px solid $bg_color;
              border-radius: 2px;
              icon-size: 16px;
              padding: 8px; }
          }

   /* World clocks */
.world-clocks-button {
  
  // city label
  .world-clocks-city {
    color: $fg_color;
    font-weight: normal;
  }

  // timezone time
  .world-clocks-time {
    font-weight: bold;
    color: $fg_color;
    font-feature-settings: "lnum";
    text-align: right;
  }

  // timezone offset label
  .world-clocks-timezone {
    color: darken($fg_color, 20%);
    font-feature-settings: "tnum";
  }
}

/* Weather */
.weather-button {

  .weather-header {
    color: darken($fg_color, 10%);
    font-weight: bold;

    &.location {
      font-weight: normal;
    }
  }

  .weather-forecast-time {
    color: darken($fg_color, 10%);
    font-feature-settings: "tnum";
    font-weight: normal;
    padding-top: 0.2em;
    padding-bottom: 0.4em;
  }

  .weather-forecast-temp {
    font-weight: bold;
  }
}

  // a little unstructured mess:

  .system-switch-user-submenu-icon.user-icon {
    icon-size: 20px;
    padding: 0 2px;
  }
  .system-switch-user-submenu-icon.default-icon {
    icon-size: 16px;
    padding: 0 4px;
  }

  #appMenu {
    spinner-image: url("assets/process-working.svg");
    spacing: 4px;

    .label-shadow { color: transparent; }
  }

  .aggregate-menu {
    min-width: 21em;
    .popup-menu-icon { padding: 0 4px; }
  }

  .system-menu-action {

    color: $fg_color;
   
    border-radius: 32px; /* wish we could do 50% */
    border: 1px solid $borders_color;
    background: darken($bg_color, 3%);
    padding: 13px;

    &:hover, &:focus {
      border: 1px solid $selected_bg_color;
      color: $selected_bg_color;
      background: transparent;
    }
    &:active {
       background-color: darken($selected_bg_color, 10%);
       color: $selected_fg_color; 
       border: 1px solid darken($selected_bg_color, 10%);
      }

    & > StIcon { icon-size: 16px; }
  }

//Activities Ripples
.ripple-box {
  width: 52px;
  height: 52px;
  background-image: url("assets/corner-ripple-ltr.png");
  background-size: contain;
}

.ripple-box:rtl {
  background-image: url("assets/corner-ripple-rtl.png");
}

// not really top bar only
.popup-menu-arrow { width: 16px; height: 16px; }
.popup-menu-icon { icon-size: 1.09em; }

//close buttons

.window-close {
  background-color: $main_dark;
  color: lighten($fg_color, 4%);
  border-radius: 30px * 0.5 + 3px * 2;
  border: 2px solid $borders_color;
  padding: 3px;
  height: 28px;
  width: 28px;
  box-shadow: -1px 1px 5px 0px rgba(0,0,0,0.5);
  transition-duration: 300ms;

  & StIcon { icon-size: 23px; }

  &:hover {
    border-color: $selected_bg_color;
  }

  &:active {
    color: $purple;
    background-color: darken($osd_bg_color, 5%);
  }
}
  .window-close {
    -shell-close-overlap: 16px;
    &:rtl { -st-background-image-shadow: 2px 2px 6px rgba(0,0,0,0.5); }
  }

/* NETWORK DIALOGS */

.nm-dialog {
  max-height: 34em;
  min-height: 31em;
  min-width: 32em;
}

  .nm-dialog-content {
    spacing: 20px;
    padding: 24px;
  }
  .nm-dialog-header-hbox { spacing: 10px; }
  .nm-dialog-airplane-box { spacing: 12px; }

  .nm-dialog-airplane-headline {
    font-weight: bold;
    text-align: center;
  }

  .nm-dialog-airplane-text { color: $fg_color; }
  .nm-dialog-header-icon { icon-size: 32px; }
  .nm-dialog-scroll-view { border: 2px solid $borders_color; background: $bg_color; }
  .nm-dialog-header { font-weight: bold; }

  .nm-dialog-item {
    font-size: 110%;
    border-bottom: 1px solid $borders_color;
    padding: 12px;
    spacing: 20px;
  }

  .nm-dialog-item:selected {
    background-color: $selected_bg_color;
    color: $selected_fg_color;
  }

  .nm-dialog-icons { spacing: .5em; }
  .nm-dialog-icon { icon-size: 16px; }
  .no-networks-label { color: #999999; }
  .no-networks-box { spacing: 12px; }

/* OVERVIEW */

#overview,.controls-manager, .secondary-monitor-workspaces {
  spacing: 24px; //
}

#overviewGroup {
  background-color: $base_color;
}

.overview-controls {
  padding-bottom: 32px;
}

  .window-picker { //container around window thumbnails
    -horizontal-spacing: 16px;
    -vertical-spacing: 16px;

    &.external-monitor { padding: 16px; }
  }

  .window-clone-border {
    border: 1px solid transparentize(rgba(255, 255, 255, 0.3),.7);
    border-radius: 0px;
    // For window decorations with round corners we can't match
    // the exact shape when the window is scaled. So apply a shadow
    // to fix that case
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.3);
  }
  .window-caption {
    spacing: 20px;
    color: $topbar_color;
    background-color: $main_dark;
    border: 1px solid $borders_color;
    padding: 4px 8px;
  }

  //search entry
  .search-entry {
    width: 320px;
    padding: 9px;
    border-radius: 10px;
    color: $fg_color;
    border-color: transparent;

    .search-entry-icon { icon-size: 1em; padding: 0 4px; color: transparentize($fg_color,.3); }

  }

  //search results

  %search-section-content-item {  
    &:focus,
    &:hover,
    &:selected {
      background-color: transparentize($osd_fg_color, .9);
      transition-duration: 200ms;
    }

    &:active,
    &:checked {
      background-color: transparentize(darken($osd_bg_color, 10%), .1);
    }
  }

  #searchResultsBin {
    max-width: 1000px;
  }

  #searchResultsContent {
    padding-left: 20px;
    padding-right: 20px;
    spacing: 16px;
  }

  .search-section { spacing: 16px; } // This should be equal to #searchResultsContent spacing
  .search-section-content { 
    background-color: transparent;
    border-radius: 0;
    border: none;
    box-shadow: none;
    // This is the space between the provider icon and the results container
    spacing: 32px; 
  }
  .search-statustext { // "no results"
    @extend %status_text;
  }
  .list-search-results { spacing: 3px; }

  .search-section-separator { height: 2px; background-color: $gray; }

  .list-search-result-content { spacing: 30px; }
  .list-search-result-title { color: lighten($topbar_color,5%); spacing: 12px; }
  .list-search-result-description { color: transparentize(lighten($topbar_color,15%), 0.5); }
  .list-search-provider-details { width: 150px; color: lighten($topbar_color,5%); margin-top: 0.24em; }
  .list-search-provider-content { spacing: 20px; }
  .search-provider-icon { padding: 15px; }

  //Icon tile
  .search-provider-icon,
  .list-search-result {
    @extend %search-section-content-item;
  }


  /* DASHBOARD */

  .dash-background {
    background-color: $main_dark;
  }

  .dash-separator {
    width: 1px;
    background-color: $gray;
  }

  .dash-label { //osd tooltip
    border-radius: 7px;
    padding: 4px 12px;
    color: $topbar_color;
    background-color: $topbar_bg_color;
    text-align: center;
    -x-offset: 8px;
  }

  /* App Vault/Grid */
  .icon-grid {
    spacing: 30px;
    -shell-grid-horizontal-item-size: 136px;
    -shell-grid-vertical-item-size: 136px;

    .overview-icon { icon-size: 96px; }
  }
  //.app-display { spacing: 20px; }

  .system-action-icon {
    background-color: black;
    color: white;
    border-radius: 99px;
    icon-size: 48px;
  }

  .app-view-controls { //favorties | all toggle container
    padding-bottom: 32px;

  }
  .app-view-control { //favorties | all toggle button
    padding: 4px 32px;
    &:checked { @include button(active); }
    &:first-child {
      border-right-width: 0;
      border-radius: 3px 0 0 3px;
    }
    &:last-child {
     border-radius: 0 3px 3px 0;
    }
  }

  .app-well-app,
  .app-well-app.app-folder,
  .show-apps,
  .grid-search-result {
    
    border: none;
    & .overview-icon {
      @extend %icon_tile;
    }
    
    &:hover .overview-icon,
    &:focus .overview-icon,
    &:selected .overview-icon {
      background-color: lighten($bg_color, 7%);
      transition-duration: 0ms;
      border-image: none;
      background-image: none;
    }

    &:active .overview-icon,
    &:checked .overview-icon {
      background-color: lighten($bg_color, 7%);
      box-shadow: inset $depth2;
      color: $fg_color;
    }

  }

  .app-well-app-running-dot { //running apps indicator
    width: 4px; height: 4px;
    background-color: $selected_bg_color;
    border-radius: 10px !important;
    box-shadow: 0px 0px 5px 4px transparentize($purple, 0.2);
    margin-bottom: 0px;
  }

  %icon_tile {
    color: $selected_fg_color;
    padding: 6px;
    border: none;
    transition-duration: 100ms;
    text-align: center;
    box-shadow: none;
  }

/* App Folders */
.app-well-app.app-folder {
  background-color: lighten($bg_color, 7%);
  border-radius: 10px;
}
// expanded folder
.app-folder-dialog { //style like the dash
  background-color:  $main_dark;
  border: none;

  & .folder-name-label { color: $fg_color; }
  
  .edit-folder-button {
    @extend %button;

    padding: 0;
    width: 36px;
    height: 36px;
    border-radius: 18px;

    & > StIcon { icon-size: 16px }
  }
}

  .app-well-app.app-folder > .overview-icon {
    background-color: transparentize($osd_bg_color,.6);
  }
  .show-apps .show-apps-icon {
    color: $topbar_color;
  }
  .show-apps:checked .show-apps-icon,
  .show-apps:focus .show-apps-icon {
    color: $fg_color;
    transition-duration: 100ms;
  }


  // Collections
  .app-folder-popup { //expanded collection
    -arrow-border-radius: 8px;
    -arrow-background-color: transparentize($bg_color,0.5);
    -arrow-base: 24px;
    -arrow-rise: 11px;
  }
  .app-folder-popup-bin { padding: 5px; background: transparentize($bg_color,.5);;}
  .app-folder-icon {
    padding: 5px;
    spacing-rows: 5px;
    spacing-columns: 5px;
  }

  .page-indicator {
    padding: 6px 12px;

    .page-indicator-icon {
      width: 12px;
      height: 12px;
      border-radius: 12px;
      background-image: none;
      background-color: lighten($base_color, 30%);
      border: 1px solid $borders_color;
    }

    &:hover .page-indicator-icon {  
      background-image: none;
      background-color: rgba(255, 255, 255, 0.5); 
    }
    &:active .page-indicator-icon { 
      background-image: none;
      background-color: rgba(255, 255, 255, 0.7);
      margin: 0;
    }
    &:checked .page-indicator-icon{ 
      background-image: none;
      background-color: #FFFFFF;
      transition-duration: 0.3s; 
      transition-timing-function: ease-in-out;
    }
  }

  .no-frequent-applications-label { @extend %status_text; }

  .app-well-app > .overview-icon.overview-icon-with-label,
  .grid-search-result .overview-icon.overview-icon-with-label {
    padding: 10px 8px 5px 8px;
    spacing: 4px;
  }

  // Workspace pager
  .workspace-thumbnails { //container ala dash
    @extend %overview-panel;
    visible-width: 32px; //amount visible before hover
    spacing: 11px;
    padding: 8px;
    border-radius: 0;
    //border-width: 1px 0 1px 1px; //fixme: can't have non unoform borders :(
    &:rtl { border-radius: 0;}
  }
  .workspace-thumbnail-indicator {
    border: 4px solid transparentize($selected_bg_color, .1);
    box-shadow: $depth;
    padding: 0;
  }

  //Some hacks I don't even
  .search-display > StBoxLayout,
  .all-apps,
  .frequent-apps > StBoxLayout {
    // horizontal padding to make sure scrollbars or dash don't overlap content
    padding: 0px 88px 10px 88px;
  }

  .page-navigation-arrow {
    &  > StIcon {
      margin: 6px;
      padding: 18px;
      width: 24px;
      height: 24px;
      border-radius: 99px;
    }
  
    &:insensitive > StIcon { @include button(undecorated, $osd_fg_color, transparentize($osd_bg_color, 0.5));}
    &:hover > StIcon { background-color: transparentize($selected_bg_color, 0.2);}
    &:active > StIcon {background-color: $selected_bg_color;}
  }

%overview-panel {
  color:  $_bubble_fg_color;
  background-color: transparent;
  border: none;
}

%status_text {
  font-size: 2em;
  font-weight: bold;
  color: $fg_color;
}

/* NOTIFICATIONS & MESSAGE TRAY */

  .url-highlighter { link-color: lighten($selected_bg_color,10%); }

  // Banners
  .notification-banner {
    font-size: 11pt;
    width: 34em;
    margin: 5px;
    border-radius: 12px;
    color: $topbar_color;
    background-color: lighten($base_color, 2%);
    border: 1px solid $borders_color;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.4);
    &:hover, &:focus { 
      background-color: lighten($base_color, 4%); 
      border-radius: 12px;
      box-shadow: none;
    }
    *{ color: #fefefe; }

    .notification-icon { padding: 5px; }
    .notification-content { padding: 5px; spacing: 5px; }
    .secondary-icon { icon-size: 1.09em; }
    .notification-actions {
      background-color: darken($bg_color, 2%);
      padding-top: 2px;
      spacing: 1px;
      border-radius: 0px 0px 12px 12px;
    }
    .notification-button {
      padding: 7px;
      background-color: transparentize($bg_color, 0.1);
      box-shadow: none;
      &:first-child { border-radius: 0 0 0 12px; }
      &:last-child { border-radius: 0 0 12px 0; }
      &:hover, &focus { background-color: $selected_bg_color; color: $selected_fg_color;}
    }
  }
  .summary-source-counter {
    font-size: 10pt;
    font-weight: bold;
    height: 1.6em; width: 1.6em;
    -shell-counter-overlap-x: 3px;
    -shell-counter-overlap-y: 3px;
    background-color: $selected_bg_color;
    color: $selected_fg_color;
    border: 2px solid $osd_fg_color;
    box-shadow: 0 2px 2px rgba(0,0,0,0.5);
    border-radius: 0.9em; // should be 0.8 but whatever; wish I could do 50%;
  }

  .secondary-icon { icon-size: 1.09em; }

  //chat bubbles
  .chat-body { spacing: 5px; }
  .chat-response { margin: 5px; }
  .chat-log-message { color: darken($fg_color,10%); }
  .chat-new-group { padding-top: 1em; }
  .chat-received {
    padding-left: 4px;
    &:rtl { padding-left: 0px; padding-right: 4px; }
  }
  .chat-sent {
    padding-left: 18pt;
    color: darken($fg_color, 15%);
    &:rtl { padding-left: 0; padding-right: 18pt; }
  }
  .chat-meta-message {
    padding-left: 4px;
    font-size: 9pt;
    font-weight: bold;
    color: darken($fg_color,20%);
    &:rtl { padding-left: 0; padding-right: 4px; }
  }

  //hotplug
  .hotplug-transient-box {
    spacing: 6px;
    padding: 2px 72px 2px 12px;
  }
    .hotplug-notification-item {
      padding: 2px 10px;
      &:focus { padding: 1px 71px 1px 11px; }
    }

    .hotplug-notification-item-icon {
      icon-size: 24px;
      padding: 2px 5px;
    }

    .hotplug-resident-box { spacing: 8px; }

    .hotplug-resident-mount {
      spacing: 8px;
      border-radius: 4px;
      &:hover { background-color: transparentize($bg_color,0.7); }
    }

    .hotplug-resident-mount-label {
      color: inherit;
      padding-left: 6px;
    }

    .hotplug-resident-mount-icon {
      icon-size: 24px;
      padding-left: 6px;
    }

    .hotplug-resident-eject-icon {
      icon-size: 16px;
    }

    .hotplug-resident-eject-button {
      padding: 7px;
      border-radius: 5px;
      color: pink;
    }

/* Eeeky things */

//magnifier

.magnifier-zoom-region {
  border: 2px solid $selected_bg_color;
  &.full-screen { border-width: 0; }
}

//Keyboard
/* On-screen Keyboard */

#keyboard {
    background-color: transparentize($osd_bg_color, 0.3);
}

  .keyboard-layout {
    spacing: 10px;
    padding: 10px;
  }

  .keyboard-row { spacing: 15px; }

  .keyboard-key {
   @include button(normal);
    background-color: $base_color;
    min-height: 2em;
    min-width: 2em;
    font-size: 14pt;
    font-weight: bold;
    border-radius: 5px;
    &:focus { @include button(focus); }
    &:hover,&:checked { @include button(hover); }
    &:active { @include button(active);}
    &:grayed { //FIXME
      background-color: $osd_bg_color;
      color: $osd_fg_color;
      border-color: $osd_borders_color;
    }
  }

  .keyboard-subkeys { //long press on a key popup
    color: white;
    padding: 5px;
    -arrow-border-radius: 10px;
    -arrow-background-color: transparentize($osd_bg_color, 0.3);
    -arrow-border-width: 2px;
    -arrow-border-color: $_bubble_borders_color;
    -arrow-base: 20px;
    -arrow-rise: 10px;
    -boxpointer-gap: 5px;
  }

// IBus Candidate Popup

.candidate-popup-content {
  padding: 0.5em;
  spacing: 0.3em;
}

  .candidate-index {
    padding: 0 0.5em 0 0;
    color: darken($fg_color,10%);
  }

  .candidate-box {
    padding: 0.3em 0.5em 0.3em 0.5em;
    border-radius: 4px;
    &:selected,&:hover { background-color: $selected_bg_color; color: $selected_fg_color; }
  }

  .candidate-page-button-box {
    height: 2em;
    .vertical & { padding-top: 0.5em; }
    .horizontal & { padding-left: 0.5em; }
  }

  .candidate-page-button {
    padding: 4px;
  }

  .candidate-page-button-previous { border-radius: 4px 0px 0px 4px; border-right-width: 0; }
  .candidate-page-button-next { border-radius: 0px 4px 4px 0px;  }
  .candidate-page-button-icon { icon-size: 1em; }

/* Auth Dialogs & Screen Shield */

.framed-user-icon {
  background-size: contain;
  border: 2px solid $osd_fg_color;
  color: $osd_fg_color;
  border-radius: 3px;
  &:hover {
    border-color: lighten($osd_fg_color,30%);
    color: lighten($osd_fg_color,30%);
  }
}

// LOGIN DIALOG

.login-dialog-banner-view {
  padding-top: 24px;
  max-width: 23em;
}

.login-dialog {
  //reset
  border: none;
  background-color: transparent;

  .modal-dialog-button-box { spacing: 3px; }
  .modal-dialog-button {
    padding: 3px 18px;
    &:default {
      @include button(normal,$c:$selected_bg_color);
      &:hover,&:focus { @include button(hover,$c:$selected_bg_color); }
      &:active { @include button(active,$c:$selected_bg_color); }
      &:insensitive { @include button(insensitive); }

    }
  }

}

  .login-dialog-logo-bin { padding: 24px 0px; }
  .login-dialog-banner { color: darken($osd_fg_color,10%); }
  .login-dialog-button-box { spacing: 5px; }
  .login-dialog-message-warning { color: $warning_color; }
  .login-dialog-message-hint { padding-top: 0; padding-bottom: 20px; }
  .login-dialog-user-selection-box { padding: 100px 0px; }
  .login-dialog-not-listed-label {
    padding-left: 2px;
    .login-dialog-not-listed-button:focus &,
    .login-dialog-not-listed-button:hover & {
      color: $osd_fg_color;
    }
  }
  .login-dialog-not-listed-label {
    font-size: 90%;
    font-weight: bold;
    color: darken($osd_fg_color,30%);
    padding-top: 1em;
  }

  .login-dialog-user-list-view { -st-vfade-offset: 1em; }
  .login-dialog-user-list {
    spacing: 12px;
    padding: .2em;
    width: 23em;
    &:expanded .login-dialog-user-list-item:selected { background-color: $selected_bg_color; color: $selected_fg_color; }
    &:expanded .login-dialog-user-list-item:logged-in { border-right: 2px solid $selected_bg_color; }
  }
  .login-dialog-user-list-item {
    border-radius: 5px;
    padding: .2em;
    color: darken($osd_fg_color,30%);
    &:ltr { padding-right: 1em; }
    &:rtl { padding-left: 1em; }
    .login-dialog-timed-login-indicator {
      height: 2px;
      margin: 2px 0 0 0;
      background-color: $osd_fg_color;
    }
    &:focus .login-dialog-timed-login-indicator { background-color: $selected_fg_color; }
  }

  .login-dialog-username,
  .user-widget-label {
    color: $osd_fg_color;
    font-size: 120%;
    font-weight: bold;
    text-align: left;
    padding-left: 15px;
  }
    .user-widget-label {
      &:ltr { padding-left: 18px; }
      &:rtl { padding-right: 18px; }
    }

  .login-dialog-prompt-layout {
      padding-top: 24px;
      padding-bottom: 12px;
      spacing: 8px;
      width: 23em;
  }

  .login-dialog-prompt-label {
      color: darken($osd_fg_color, 20%);
      font-size: 110%;
      padding-top: 1em;
  }

  .login-dialog-session-list-button StIcon {
      icon-size: 1.25em;
  }

  .login-dialog-session-list-button {
      color: darken($osd_fg_color,30%);
      &:hover,&:focus { color: $osd_fg_color; }
      &:active { color: darken($osd_fg_color, 50%); }
  }

//SCREEN SHIELD

.screen-shield-arrows {
    padding-bottom: 3em;
}

.screen-shield-arrows Gjs_Arrow {
    color: white;
    width: 80px;
    height: 48px;
    -arrow-thickness: 12px;
    -arrow-shadow: 0 1px 1px rgba(0,0,0,0.4);
}

.screen-shield-clock {
  color: white;
  text-shadow: 0px 1px 2px rgba(0,0,0,0.6);
  font-weight: bold;
  text-align: center;
  padding-bottom: 1.5em;
}

.screen-shield-clock-time {
  font-size: 72pt;
  text-shadow: 0px 2px 2px rgba(0,0,0,0.4);
}

.screen-shield-clock-date { font-size: 28pt; }

.screen-shield-notifications-container {
  spacing: 6px;
  width: 30em;
  background-color: transparent;
  max-height: 500px;
  .summary-notification-stack-scrollview {
    padding-top: 0;
    padding-bottom: 0;
  }

  .notification,
  .screen-shield-notification-source {
    padding: 12px 6px;
    border: 1px solid $_bubble_borders_color;
    background-color: transparentize($osd_bg_color,0.5);
    color: $_bubble_fg_color;
    border-radius: 4px;
  }
  .notification { margin-right: 15px; } //compensate for space allocated to the scrollbar
}


.screen-shield-notification-label {
  font-weight: bold;
  padding: 0px 0px 0px 12px;
}

.screen-shield-notification-count-text { padding: 0px 0px 0px 12px; }

#panel.lock-screen { background-color: transparentize($_bubble_bg_color, 0.5); }

.screen-shield-background { //just the shadow, really
  background: black;
  box-shadow: 0px 2px 4px transparentize(black,0.6);
}

#lockDialogGroup {
  background: #2e3436 url(resource:///org/gnome/shell/theme/noise-texture.png);
  background-repeat: repeat;
}

#screenShieldNotifications {
  StButton#vhandle, StButton#hhandle {
    background-color: transparentize($bg_color,0.7);
    &:hover, &:focus { background-color: transparentize($bg_color,0.5); }
    &:active { background-color: transparentize($selected_bg_color, 0.1); }
  }
}


// Looking Glass
#LookingGlassDialog {
  background-color: rgba(0,0,0,0.80);
  spacing: 4px;
  padding: 4px;
  border: 2px solid grey;
  border-radius: 4px;
  & > #Toolbar {
    border: 1px solid grey;
    border-radius: 4px;
  }
  .labels { spacing: 4px; }
  .notebook-tab {
    -natural-hpadding: 12px;
    -minimum-hpadding: 6px;
    font-weight: bold;
    color: #ccc;
    transition-duration: 100ms;
    padding-left: .3em;
    padding-right: .3em;
    &:hover {
      color: white;
      text-shadow: black 0px 2px 2px;
    }
    &:selected {
      border-bottom-width: 2px;
      border-color: lighten($selected_bg_color,5%);
      color: white;
      text-shadow: black 0px 2px 2px;
    }
  }
  StBoxLayout#EvalBox { padding: 4px; spacing: 4px; }
  StBoxLayout#ResultsArea { spacing: 4px; }
}

  .lg-dialog {
    StEntry {
      selection-background-color: #bbbbbb;
      selected-color: #333333;
    }
    .shell-link {
      color: #999999;
      &:hover { color: #dddddd; }
     }
  }

  .lg-completions-text {
      font-size: .9em;
      font-style: italic;
  }

  .lg-obj-inspector-title {
      spacing: 4px;
  }

  .lg-obj-inspector-button {
      border: 1px solid gray;
      padding: 4px;
      border-radius: 4px;
      &:hover { border: 1px solid #ffffff; }
  }

  #lookingGlassExtensions { padding: 4px; }

  .lg-extensions-list {
      padding: 4px;
      spacing: 6px;
  }

  .lg-extension {
      border: 1px solid #6f6f6f;
      border-radius: 4px;
      padding: 4px;
  }

  .lg-extension-name {
      font-weight: bold;
  }

  .lg-extension-meta {
      spacing: 6px;
  }

  #LookingGlassPropertyInspector {
    background: rgba(0, 0, 0, 0.8);
    border: 2px solid grey;
    border-radius: 4px;
    padding: 6px;
  }

// Gnome 43 quick settings menu

  .quick-settings {
    padding: 14px;
    border-radius: 12px;
  
    .icon-button, .button {
      padding: 6px*1.75;
    }
  }
  
  $base_padding: 6px;
  
  .quick-toggle {
    border-radius: 99px;
    min-height: 40px;
  
    &:checked { 
      @include button(active, transparentize($selected_bg_color, 0.35));
      color: $purple;
    }
  
    & > StBoxLayout { spacing: $base_padding; }
  
    /* Move padding into the box; this is to allow menu arrows
       to extend to the border */
    &.button { padding: 0; }
    & > StBoxLayout { padding: 0 6px*2; }
    &:ltr > StBoxLayout { padding-left: $base_padding*2.5; }
    &:rtl > StBoxLayout { padding-right: $base_padding*2.5; }
  
    .quick-toggle-label { font-weight: bold; }
    //.quick-toggle-icon, .quick-toggle-arrow { icon-size: $base_icon_size; }
  }
  
  .quick-menu-toggle {
    &:ltr > StBoxLayout { padding-right: 0; }
    &:rtl > StBoxLayout { padding-left: 0; }
  
    & .quick-toggle-arrow {
      background-color: transparentize($fg_color, 0.9);
      padding: $base_padding $base_padding*1.75;
  
      &:ltr { border-radius: 0 99px 99px 0; }
      &:rtl { border-radius: 99px 0 0 99px; }
    }
  }
  
  .quick-toggle-menu {
    background-color: $base_color;
    border-radius: 12px;
    padding: $base_padding*2;
    margin: $base_padding*2 $base_padding*3 0;
  
    .popup-menu-item > StIcon { -st-icon-style: symbolic; }
  
    & .header {
      spacing-rows: 0.5 * $base_padding;
      spacing-columns: $base_padding*2;
      padding-bottom: 2 * $base_padding;
  
      & .icon {
        // icon-size: $base_icon_size*1.5; // a non-standard symbolic size but ok
        border-radius: 999px;
        padding: 1.5 * $base_padding;
        background-color: lighten($bg_color, 10%);
  
        &.active { background-color: $selected_bg_color; }
      }
    }
  }
  
  .quick-settings-system-item {
    & > StBoxLayout { spacing: 2 * $base_padding; }

    .icon-button {
      @extend %button;
      border-radius: 50px;
    }
  }