297 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			CSS
		
	
	
			
		
		
	
	
			297 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			CSS
		
	
	
/* Some sane resets. */
 | 
						|
html {
 | 
						|
  height: 100%;
 | 
						|
}
 | 
						|
 | 
						|
body {
 | 
						|
  margin: 0;
 | 
						|
  min-height: 100%;
 | 
						|
}
 | 
						|
 | 
						|
/* All the flexbox magic! */
 | 
						|
body,
 | 
						|
.sb-announcement,
 | 
						|
.sb-content,
 | 
						|
.sb-main,
 | 
						|
.sb-container,
 | 
						|
.sb-container__inner,
 | 
						|
.sb-article-container,
 | 
						|
.sb-footer-content,
 | 
						|
.sb-header,
 | 
						|
.sb-header-secondary,
 | 
						|
.sb-footer {
 | 
						|
  display: flex;
 | 
						|
}
 | 
						|
 | 
						|
/* These order things vertically */
 | 
						|
body,
 | 
						|
.sb-main,
 | 
						|
.sb-article-container {
 | 
						|
  flex-direction: column;
 | 
						|
}
 | 
						|
 | 
						|
/* Put elements in the center */
 | 
						|
.sb-header,
 | 
						|
.sb-header-secondary,
 | 
						|
.sb-container,
 | 
						|
.sb-content,
 | 
						|
.sb-footer,
 | 
						|
.sb-footer-content {
 | 
						|
  justify-content: center;
 | 
						|
}
 | 
						|
/* Put elements at the ends */
 | 
						|
.sb-article-container {
 | 
						|
  justify-content: space-between;
 | 
						|
}
 | 
						|
 | 
						|
/* These elements grow. */
 | 
						|
.sb-main,
 | 
						|
.sb-content,
 | 
						|
.sb-container,
 | 
						|
article {
 | 
						|
  flex-grow: 1;
 | 
						|
}
 | 
						|
 | 
						|
/* Because padding making this wider is not fun */
 | 
						|
article {
 | 
						|
  box-sizing: border-box;
 | 
						|
}
 | 
						|
 | 
						|
/* The announcements element should never be wider than the page. */
 | 
						|
.sb-announcement {
 | 
						|
  max-width: 100%;
 | 
						|
}
 | 
						|
 | 
						|
.sb-sidebar-primary,
 | 
						|
.sb-sidebar-secondary {
 | 
						|
  flex-shrink: 0;
 | 
						|
  width: 17rem;
 | 
						|
}
 | 
						|
 | 
						|
.sb-announcement__inner {
 | 
						|
  justify-content: center;
 | 
						|
 | 
						|
  box-sizing: border-box;
 | 
						|
  height: 3rem;
 | 
						|
 | 
						|
  overflow-x: auto;
 | 
						|
  white-space: nowrap;
 | 
						|
}
 | 
						|
 | 
						|
/* Sidebars, with checkbox-based toggle */
 | 
						|
.sb-sidebar-primary,
 | 
						|
.sb-sidebar-secondary {
 | 
						|
  position: fixed;
 | 
						|
  height: 100%;
 | 
						|
  top: 0;
 | 
						|
}
 | 
						|
 | 
						|
.sb-sidebar-primary {
 | 
						|
  left: -17rem;
 | 
						|
  transition: left 250ms ease-in-out;
 | 
						|
}
 | 
						|
.sb-sidebar-secondary {
 | 
						|
  right: -17rem;
 | 
						|
  transition: right 250ms ease-in-out;
 | 
						|
}
 | 
						|
 | 
						|
.sb-sidebar-toggle {
 | 
						|
  display: none;
 | 
						|
}
 | 
						|
.sb-sidebar-overlay {
 | 
						|
  position: fixed;
 | 
						|
  top: 0;
 | 
						|
  width: 0;
 | 
						|
  height: 0;
 | 
						|
 | 
						|
  transition: width 0ms ease 250ms, height 0ms ease 250ms, opacity 250ms ease;
 | 
						|
 | 
						|
  opacity: 0;
 | 
						|
  background-color: rgba(0, 0, 0, 0.54);
 | 
						|
}
 | 
						|
 | 
						|
#sb-sidebar-toggle--primary:checked
 | 
						|
  ~ .sb-sidebar-overlay[for="sb-sidebar-toggle--primary"],
 | 
						|
#sb-sidebar-toggle--secondary:checked
 | 
						|
  ~ .sb-sidebar-overlay[for="sb-sidebar-toggle--secondary"] {
 | 
						|
  width: 100%;
 | 
						|
  height: 100%;
 | 
						|
  opacity: 1;
 | 
						|
  transition: width 0ms ease, height 0ms ease, opacity 250ms ease;
 | 
						|
}
 | 
						|
 | 
						|
#sb-sidebar-toggle--primary:checked ~ .sb-container .sb-sidebar-primary {
 | 
						|
  left: 0;
 | 
						|
}
 | 
						|
#sb-sidebar-toggle--secondary:checked ~ .sb-container .sb-sidebar-secondary {
 | 
						|
  right: 0;
 | 
						|
}
 | 
						|
 | 
						|
/* Full-width mode */
 | 
						|
.drop-secondary-sidebar-for-full-width-content
 | 
						|
  .hide-when-secondary-sidebar-shown {
 | 
						|
  display: none !important;
 | 
						|
}
 | 
						|
.drop-secondary-sidebar-for-full-width-content .sb-sidebar-secondary {
 | 
						|
  display: none !important;
 | 
						|
}
 | 
						|
 | 
						|
/* Mobile views */
 | 
						|
.sb-page-width {
 | 
						|
  width: 100%;
 | 
						|
}
 | 
						|
 | 
						|
.sb-article-container,
 | 
						|
.sb-footer-content__inner,
 | 
						|
.drop-secondary-sidebar-for-full-width-content .sb-article,
 | 
						|
.drop-secondary-sidebar-for-full-width-content .match-content-width {
 | 
						|
  width: 100vw;
 | 
						|
}
 | 
						|
 | 
						|
.sb-article,
 | 
						|
.match-content-width {
 | 
						|
  padding: 0 1rem;
 | 
						|
  box-sizing: border-box;
 | 
						|
}
 | 
						|
 | 
						|
@media (min-width: 32rem) {
 | 
						|
  .sb-article,
 | 
						|
  .match-content-width {
 | 
						|
    padding: 0 2rem;
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
/* Tablet views */
 | 
						|
@media (min-width: 42rem) {
 | 
						|
  .sb-article-container {
 | 
						|
    width: auto;
 | 
						|
  }
 | 
						|
  .sb-footer-content__inner,
 | 
						|
  .drop-secondary-sidebar-for-full-width-content .sb-article,
 | 
						|
  .drop-secondary-sidebar-for-full-width-content .match-content-width {
 | 
						|
    width: 42rem;
 | 
						|
  }
 | 
						|
  .sb-article,
 | 
						|
  .match-content-width {
 | 
						|
    width: 42rem;
 | 
						|
  }
 | 
						|
}
 | 
						|
@media (min-width: 46rem) {
 | 
						|
  .sb-footer-content__inner,
 | 
						|
  .drop-secondary-sidebar-for-full-width-content .sb-article,
 | 
						|
  .drop-secondary-sidebar-for-full-width-content .match-content-width {
 | 
						|
    width: 46rem;
 | 
						|
  }
 | 
						|
  .sb-article,
 | 
						|
  .match-content-width {
 | 
						|
    width: 46rem;
 | 
						|
  }
 | 
						|
}
 | 
						|
@media (min-width: 50rem) {
 | 
						|
  .sb-footer-content__inner,
 | 
						|
  .drop-secondary-sidebar-for-full-width-content .sb-article,
 | 
						|
  .drop-secondary-sidebar-for-full-width-content .match-content-width {
 | 
						|
    width: 50rem;
 | 
						|
  }
 | 
						|
  .sb-article,
 | 
						|
  .match-content-width {
 | 
						|
    width: 50rem;
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
/* Tablet views */
 | 
						|
@media (min-width: 59rem) {
 | 
						|
  .sb-sidebar-secondary {
 | 
						|
    position: static;
 | 
						|
  }
 | 
						|
  .hide-when-secondary-sidebar-shown {
 | 
						|
    display: none !important;
 | 
						|
  }
 | 
						|
  .sb-footer-content__inner,
 | 
						|
  .drop-secondary-sidebar-for-full-width-content .sb-article,
 | 
						|
  .drop-secondary-sidebar-for-full-width-content .match-content-width {
 | 
						|
    width: 59rem;
 | 
						|
  }
 | 
						|
  .sb-article,
 | 
						|
  .match-content-width {
 | 
						|
    width: 42rem;
 | 
						|
  }
 | 
						|
}
 | 
						|
@media (min-width: 63rem) {
 | 
						|
  .sb-footer-content__inner,
 | 
						|
  .drop-secondary-sidebar-for-full-width-content .sb-article,
 | 
						|
  .drop-secondary-sidebar-for-full-width-content .match-content-width {
 | 
						|
    width: 63rem;
 | 
						|
  }
 | 
						|
  .sb-article,
 | 
						|
  .match-content-width {
 | 
						|
    width: 46rem;
 | 
						|
  }
 | 
						|
}
 | 
						|
@media (min-width: 67rem) {
 | 
						|
  .sb-footer-content__inner,
 | 
						|
  .drop-secondary-sidebar-for-full-width-content .sb-article,
 | 
						|
  .drop-secondary-sidebar-for-full-width-content .match-content-width {
 | 
						|
    width: 67rem;
 | 
						|
  }
 | 
						|
  .sb-article,
 | 
						|
  .match-content-width {
 | 
						|
    width: 50rem;
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
/* Desktop views */
 | 
						|
@media (min-width: 76rem) {
 | 
						|
  .sb-sidebar-primary {
 | 
						|
    position: static;
 | 
						|
  }
 | 
						|
  .hide-when-primary-sidebar-shown {
 | 
						|
    display: none !important;
 | 
						|
  }
 | 
						|
  .sb-footer-content__inner,
 | 
						|
  .drop-secondary-sidebar-for-full-width-content .sb-article,
 | 
						|
  .drop-secondary-sidebar-for-full-width-content .match-content-width {
 | 
						|
    width: 59rem;
 | 
						|
  }
 | 
						|
  .sb-article,
 | 
						|
  .match-content-width {
 | 
						|
    width: 42rem;
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
/* Full desktop views */
 | 
						|
@media (min-width: 80rem) {
 | 
						|
  .sb-article,
 | 
						|
  .match-content-width {
 | 
						|
    width: 46rem;
 | 
						|
  }
 | 
						|
  .sb-footer-content__inner,
 | 
						|
  .drop-secondary-sidebar-for-full-width-content .sb-article,
 | 
						|
  .drop-secondary-sidebar-for-full-width-content .match-content-width {
 | 
						|
    width: 63rem;
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
@media (min-width: 84rem) {
 | 
						|
  .sb-article,
 | 
						|
  .match-content-width {
 | 
						|
    width: 50rem;
 | 
						|
  }
 | 
						|
  .sb-footer-content__inner,
 | 
						|
  .drop-secondary-sidebar-for-full-width-content .sb-article,
 | 
						|
  .drop-secondary-sidebar-for-full-width-content .match-content-width {
 | 
						|
    width: 67rem;
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
@media (min-width: 88rem) {
 | 
						|
  .sb-footer-content__inner,
 | 
						|
  .drop-secondary-sidebar-for-full-width-content .sb-article,
 | 
						|
  .drop-secondary-sidebar-for-full-width-content .match-content-width {
 | 
						|
    width: 67rem;
 | 
						|
  }
 | 
						|
  .sb-page-width {
 | 
						|
    width: 88rem;
 | 
						|
  }
 | 
						|
}
 |