439 lines
8.6 KiB
Plaintext
439 lines
8.6 KiB
Plaintext
/* ===========================================================================================
|
|
Base tags
|
|
============================================================================================== */
|
|
|
|
a {
|
|
text-decoration: none;
|
|
color: @light;
|
|
|
|
&.external::after {
|
|
content: " " url();
|
|
}
|
|
|
|
&.broken {
|
|
color: red;
|
|
}
|
|
}
|
|
|
|
p {
|
|
margin: 0 0 1em;
|
|
}
|
|
|
|
hr {
|
|
clear: both;
|
|
margin: 1em 0;
|
|
border: 0;
|
|
border-top: 1px solid #ddd;
|
|
}
|
|
|
|
code {
|
|
color: @dark;
|
|
}
|
|
|
|
/* ===========================================================================================
|
|
Components
|
|
============================================================================================== */
|
|
|
|
.Button {
|
|
display: inline-block;
|
|
text-align: center;
|
|
vertical-align: middle;
|
|
touch-action: manipulation;
|
|
cursor: pointer;
|
|
background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214
|
|
border: 1px solid transparent;
|
|
white-space: nowrap;
|
|
border-radius: 4px;
|
|
|
|
&--small {
|
|
font-size: 12px;
|
|
line-height: 1.5;
|
|
border-radius: 3px;
|
|
}
|
|
|
|
&--default {
|
|
color: #333;
|
|
background-color: #fff;
|
|
border-color: #ccc;
|
|
|
|
&.Button--active {
|
|
color: #333;
|
|
background-color: #e6e6e6;
|
|
border-color: #adadad;
|
|
}
|
|
}
|
|
}
|
|
|
|
.ButtonGroup {
|
|
position: relative;
|
|
display: inline-block;
|
|
vertical-align: middle; // match .Button alignment given font-size hack above
|
|
|
|
.Button + .Button {
|
|
margin-left: -1px;
|
|
}
|
|
|
|
> .Button {
|
|
position: relative;
|
|
float: left;
|
|
|
|
// Bring the "active" button to the front
|
|
&:hover,
|
|
&:focus {
|
|
z-index: 2;
|
|
}
|
|
|
|
&:active,
|
|
&.Button--active {
|
|
z-index: 3;
|
|
}
|
|
|
|
&:not(:first-child):not(:last-child) {
|
|
border-radius: 0;
|
|
}
|
|
|
|
// Set corners individual because sometimes a single button can be in a .btn-group and we need :first-child and :last-child to both match
|
|
&:first-child {
|
|
margin-left: 0;
|
|
|
|
&:not(:last-child):not(.dropdown-toggle) {
|
|
.border-right-radius(0);
|
|
}
|
|
}
|
|
|
|
// Need .dropdown-toggle since :last-child doesn't apply given a .dropdown-menu immediately after it
|
|
&:last-child:not(:first-child) {
|
|
.border-left-radius(0);
|
|
}
|
|
}
|
|
}
|
|
|
|
.Brand {
|
|
display: block;
|
|
background-color: @dark;
|
|
padding: 15px 20px;
|
|
font-size: 18px;
|
|
text-shadow: none;
|
|
font-family: @font-family-heading;
|
|
font-weight: 700;
|
|
color: @light;
|
|
}
|
|
|
|
.Navbar {
|
|
height: 50px;
|
|
box-shadow: 0 1px 5px rgba(0, 0, 0, 0.25);
|
|
background-color: @dark;
|
|
margin-bottom: 0;
|
|
|
|
.Brand {
|
|
float: left;
|
|
line-height: 20px;
|
|
height: 50px;
|
|
}
|
|
}
|
|
|
|
.CodeToggler {
|
|
&__text {
|
|
font-size: 12px;
|
|
line-height: 1.5;
|
|
padding: 6px 10px 6px 0;
|
|
display: inline-block;
|
|
vertical-align: middle;
|
|
}
|
|
}
|
|
|
|
// Sidebar navigation
|
|
.Nav {
|
|
margin: 0;
|
|
padding: 0;
|
|
|
|
&__arrow {
|
|
display: inline-block;
|
|
position: relative;
|
|
width: 16px;
|
|
margin-left: -16px;
|
|
|
|
&::before {
|
|
position: absolute;
|
|
display: block;
|
|
content: "";
|
|
margin: -0.25em 0 0 -0.4em;
|
|
left: 50%;
|
|
top: 50%;
|
|
width: 0.5em;
|
|
height: 0.5em;
|
|
border-right: 0.15em solid @dark;
|
|
border-top: 0.15em solid @dark;
|
|
transform: rotate(45deg);
|
|
transition-duration: 0.3s;
|
|
}
|
|
}
|
|
|
|
&__item {
|
|
display: block;
|
|
|
|
a {
|
|
display: block;
|
|
margin: 0;
|
|
padding: 6px 15px 6px 20px;
|
|
font-family: @font-family-heading;
|
|
font-weight: 400;
|
|
color: @dark;
|
|
font-size: 15px;
|
|
text-shadow: none;
|
|
border-color: @lines;
|
|
|
|
&:hover {
|
|
color: @dark;
|
|
text-shadow: none;
|
|
background-color: @sidebar-hover;
|
|
}
|
|
}
|
|
}
|
|
|
|
.Nav {
|
|
display: none;
|
|
margin-left: 15px;
|
|
|
|
.Nav__item {
|
|
a {
|
|
margin: 0;
|
|
margin-left: -15px;
|
|
padding: 3px 30px;
|
|
font-family: @font-family-text;
|
|
color: @text;
|
|
opacity: 0.7;
|
|
|
|
&:hover {
|
|
opacity: 1;
|
|
}
|
|
}
|
|
|
|
&--active a {
|
|
color: @dark;
|
|
}
|
|
}
|
|
}
|
|
|
|
&__item {
|
|
&--open,
|
|
&--active {
|
|
> a {
|
|
background-color: @sidebar-hover;
|
|
}
|
|
}
|
|
|
|
&--open {
|
|
> .Nav {
|
|
display: block;
|
|
}
|
|
|
|
> a > .Nav__arrow::before {
|
|
margin-left: -0.25em;
|
|
transform: rotate(135deg);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
.Page__header {
|
|
margin: 0 0 10px;
|
|
padding: 0;
|
|
border-bottom: 1px solid #eee;
|
|
|
|
.clearfix();
|
|
|
|
h1 {
|
|
margin: 0;
|
|
padding: 0;
|
|
line-height: 57px;
|
|
}
|
|
|
|
&--separator {
|
|
height: 0.6em;
|
|
}
|
|
|
|
a {
|
|
text-decoration: none;
|
|
}
|
|
}
|
|
|
|
.Links {
|
|
padding: 0 20px;
|
|
|
|
a {
|
|
font-family: @font-family-heading;
|
|
font-weight: 400;
|
|
color: @light;
|
|
line-height: 2em;
|
|
}
|
|
}
|
|
|
|
.Search {
|
|
position: relative;
|
|
|
|
&__field {
|
|
display: block;
|
|
width: 100%;
|
|
height: 34px;
|
|
padding: 6px 30px 6px 20px;
|
|
color: #555;
|
|
border-width: 0 0 1px;
|
|
border-bottom: 1px solid #ccc;
|
|
background: #fff;
|
|
transition: border-color ease-in-out 0.15s;
|
|
|
|
&:focus {
|
|
border-color: @light;
|
|
outline: 0;
|
|
}
|
|
}
|
|
|
|
&__icon {
|
|
position: absolute;
|
|
right: 9px;
|
|
top: 9px;
|
|
width: 16px;
|
|
height: 16px;
|
|
}
|
|
}
|
|
|
|
.Navbar .Search {
|
|
float: right;
|
|
margin: 8px 20px;
|
|
|
|
&__field {
|
|
box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
|
|
border-width: 0;
|
|
border-radius: 4px;
|
|
padding-left: 10px;
|
|
}
|
|
}
|
|
|
|
.TableOfContents {
|
|
font-size: 16px;
|
|
padding-left: 0;
|
|
border-left: 6px solid #efefef;
|
|
|
|
p {
|
|
margin-bottom: 0;
|
|
}
|
|
|
|
a {
|
|
text-decoration: none;
|
|
}
|
|
|
|
.TableOfContents {
|
|
border-left-width: 0;
|
|
}
|
|
}
|
|
|
|
.Pager {
|
|
padding-left: 0;
|
|
margin: 1em 0;
|
|
list-style: none;
|
|
text-align: center;
|
|
clear: both;
|
|
|
|
.clearfix();
|
|
|
|
li {
|
|
display: inline;
|
|
|
|
> a {
|
|
display: inline-block;
|
|
padding: 5px 14px;
|
|
background-color: #fff;
|
|
border: 1px solid #ddd;
|
|
border-radius: 15px;
|
|
}
|
|
|
|
> a:hover,
|
|
> a:focus {
|
|
text-decoration: none;
|
|
background-color: #eee;
|
|
}
|
|
}
|
|
|
|
&--next > a {
|
|
float: right;
|
|
}
|
|
|
|
&--prev > a {
|
|
float: left;
|
|
}
|
|
}
|
|
|
|
.Checkbox {
|
|
position: relative;
|
|
display: block;
|
|
padding-left: 30px;
|
|
cursor: pointer;
|
|
|
|
input {
|
|
position: absolute;
|
|
z-index: -1;
|
|
opacity: 0;
|
|
}
|
|
}
|
|
|
|
.Checkbox__indicator {
|
|
position: absolute;
|
|
top: 2px;
|
|
left: 0;
|
|
width: 20px;
|
|
height: 20px;
|
|
background: #e6e6e6;
|
|
|
|
/* Check mark */
|
|
&::after {
|
|
position: absolute;
|
|
display: none;
|
|
content: '';
|
|
}
|
|
|
|
/* Hover and focus states */
|
|
.Checkbox:hover input ~ &,
|
|
.Checkbox input:focus ~ & {
|
|
background: #ccc;
|
|
}
|
|
|
|
/* Checked state */
|
|
.Checkbox input:checked ~ & {
|
|
background: @dark;
|
|
|
|
/* Show check mark */
|
|
&::after {
|
|
display: block;
|
|
}
|
|
}
|
|
|
|
/* Hover state whilst checked */
|
|
.Checkbox:hover input:not([disabled]):checked ~ &, .Checkbox input:checked:focus ~ & {
|
|
background: @light;
|
|
}
|
|
|
|
/* Disabled state */
|
|
.Checkbox input:disabled ~ & {
|
|
pointer-events: none;
|
|
opacity: 0.6;
|
|
background: #e6e6e6;
|
|
}
|
|
|
|
/* Checkbox tick */
|
|
.Checkbox &::after {
|
|
top: 4px;
|
|
left: 8px;
|
|
width: 5px;
|
|
height: 10px;
|
|
transform: rotate(45deg);
|
|
border: solid #fff;
|
|
border-width: 0 2px 2px 0;
|
|
}
|
|
|
|
/* Disabled tick colour */
|
|
.Checkbox input:disabled ~ &::after {
|
|
border-color: #7b7b7b;
|
|
}
|
|
}
|