/*! normalize.css v7.0.0 | MIT License | github.com/necolas/normalize.css */
html {
  line-height: 1.15;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0
}

article,
aside,
footer,
header,
nav,
section {
  display: block
}

h1 {
  font-size: 2em;
  margin: .67em 0
}

figcaption,
figure,
main {
  display: block
}

figure {
  margin: 1em 40px
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
}

pre {
  font-family: monospace, monospace;
  font-size: 1em;
}

a {
  background-color: rgba(0, 0, 0, 0);
  -webkit-text-decoration-skip: objects;
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted;
}

b,
strong {
  font-weight: inherit
}

b,
strong {
  font-weight: bolder
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

dfn {
  font-style: italic
}

mark {
  background-color: #ff0;
  color: #000
}

small {
  font-size: 80%
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline
}

sub {
  bottom: -.25em
}

sup {
  top: -.5em
}

audio,
video {
  display: inline-block
}

audio:not([controls]) {
  display: none;
  height: 0
}

img {
  border-style: none
}

svg:not(:root) {
  overflow: hidden
}

button,
input,
optgroup,
select,
textarea {
  font-family: sans-serif;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}

button,
input {
  overflow: visible
}

button,
select {
  text-transform: none
}

button,
html [type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0
}

button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText
}

fieldset {
  padding: .35em .75em .625em
}

legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}

progress {
  display: inline-block;
  vertical-align: baseline;
}

textarea {
  overflow: auto
}

[type=checkbox],
[type=radio] {
  box-sizing: border-box;
  padding: 0;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type=search]::-webkit-search-cancel-button,
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

details,
menu {
  display: block
}

summary {
  display: list-item
}

canvas {
  display: inline-block
}

template {
  display: none
}

[hidden] {
  display: none
}

* {
  box-sizing: border-box
}

html {
  font-size: 62.5%
}

body,
html {
  height: 100%
}

body {
  text-rendering: optimizeLegibility;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 14px;
  letter-spacing: .2px
}

.menu {
  height: 100%;
  position: absolute;
  left: 0;
  overflow-y: auto;
  width: 300px;
  color: #364149;
  background: #fafafa;
  border-right: 1px solid rgba(0, 0, 0, .07);
  transition: .5s
}

.menu ul {
  list-style: none;
  margin: 0;
  padding: 0
}

.menu ul a {
  display: block;
  color: #364149;
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
  text-decoration: none;
  padding: 10px 15px
}

.menu ul a:hover {
  text-decoration: underline
}

.menu ul li.active>a {
  color: #0053bc;
  text-decoration: none
}

.menu ul ul {
  padding-left: 20px
}

.menu-hidden {
  width: 0
}

@media screen and (max-width: 600px) {
  .menu {
    width: 0;
    z-index: 1
  }

  .menu-hidden {
    width: calc(100% - 100px);
    z-index: 0
  }
}

.page {
  position: absolute;
  width: calc(100% - 300px);
  height: 100%;
  overflow-y: auto;
  color: #000;
  background: #fff;
  padding-bottom: 20px;
  transition: .5s
}

.page .zola-anchor {
  color: #357aba;
  padding-left: 10px;
  text-decoration: none;
  font-weight: initial
}

.page .zola-anchor:hover {
  text-decoration: underline
}

.page img {
  max-width: 100%
}

.page__content {
  font-size: 1.6rem;
  word-wrap: break-word;
  line-height: 1.7;
  position: relative;
  left: 0;
  max-width: 800px;
  margin: 0 auto;
  padding: 0 15px 40px
}

.page__content a {
  color: #357aba;
  text-decoration: none
}

.page__content a:hover {
  text-decoration: underline
}

.page__content hr {
  height: 4px;
  padding: 0;
  margin: 1.7em 0;
  overflow: hidden;
  background-color: #e7e7e7;
  border: none
}

.page__content pre {
  padding: 1rem
}

.page__content pre span {
  white-space: pre-wrap
}

.page__content blockquote {
  margin: 0;
  margin-bottom: .85em;
  padding: 0 15px;
  color: #858585;
  border-left: 4px solid #e5e5e5
}

.page__content pre code {
  background: none
}

.page__content code {
  display: inline-block;
  vertical-align: middle;
  padding: .1em .3em;
  border-radius: 3px;
  color: #fff3c0;
  background: #263238;
  font-size: .875em;
  font-family: "Source Code Pro", Consolas, "Ubuntu Mono", Menlo, "DejaVu Sans Mono", monospace, monospace
}

.page__content iframe {
  border: 0
}

.page__content table {
  margin: 0 auto;
  border-collapse: collapse;
  border-color: #ccc
}

.page__content table td {
  padding: 3px 20px;
  border: 1px solid #ccc
}

.page__content table thead th {
  padding: 6px 13px;
  font-weight: bold;
  border: 1px solid #ccc
}

.page__content p {
  margin-top: 0;
  margin-bottom: .85em
}

.page .previous,
.page .next {
  position: fixed;
  display: flex;
  top: 50px;
  bottom: 0;
  font-size: 2.5em;
  color: #ccc;
  text-decoration: none;
  text-align: center;
  margin: 0;
  max-width: 150px;
  min-width: 90px;
  justify-content: center;
  align-content: center;
  flex-direction: column
}

.page .previous:hover,
.page .next:hover {
  color: #333
}

.page .previous {
  left: 300px;
  float: left;
  transition: left .5s
}

.page .next {
  right: 15px;
  float: right
}

@media screen and (max-width: 1250px) {

  .page .previous,
  .page .next {
    position: static;
    top: auto;
    display: inline-block;
    max-width: 49%;
    width: 49%
  }

  .page .previous:hover,
  .page .next:hover {
    text-decoration: none
  }
}

@media screen and (min-width: 600px) {
  .page {
    left: 300px
  }
}

.page-without-menu {
  width: 100%;
  left: 0
}

.page-without-menu .previous {
  left: 15px
}

@media screen and (max-width: 600px) {
  .page {
    width: 100%;
    left: 0
  }

  .page-without-menu {
    left: calc(100% - 100px)
  }
}

.search-container {
  display: none
}

.search-container--is-visible {
  display: block
}

.search-container #search {
  width: 100%;
  padding: 1rem;
  border: 1px solid #aaa;
  border-radius: 3px;
  background-color: #fafafa;
  color: #000
}

.search-container .search-results__header {
  font-weight: bold;
  padding: 1rem 0rem
}

.search-container .search-results__items {
  margin: 0;
  padding: 0;
  list-style: none
}

.search-container .search-results__item {
  margin-bottom: 1rem
}

.search-container .search-results__teaser {
  font-size: 90%
}

.search-mode .prev-link,
.search-mode .next-link {
  display: none
}

.giallo-l {
  display: inline-block;
  min-height: 1lh;
  width: 100%
}

.giallo-ln {
  display: inline-block;
  user-select: none;
  margin-right: .4em;
  padding: .4em;
  min-width: 3ch;
  text-align: right;
  opacity: .8
}

.page__header {
  height: 50px
}

.page__header .menu-icon {
  height: 50px;
  width: 50px;
  font-size: 24px;
  text-align: center;
  float: left;
  position: relative;
  transition: background .5s;
  cursor: pointer
}

@keyframes clickfirst {
  0% {
    transform: translateY(6px) rotate(0deg)
  }

  100% {
    transform: translateY(0) rotate(45deg)
  }
}

@keyframes clickmid {
  0% {
    opacity: 1
  }

  100% {
    opacity: 0
  }
}

@keyframes clicklast {
  0% {
    transform: translateY(-6px) rotate(0deg)
  }

  100% {
    transform: translateY(0) rotate(-45deg)
  }
}

@keyframes outfirst {
  0% {
    transform: translateY(0) rotate(-45deg)
  }

  100% {
    transform: translateY(-6px) rotate(0deg)
  }
}

@keyframes outmid {
  0% {
    opacity: 0
  }

  100% {
    opacity: 1
  }
}

@keyframes outlast {
  0% {
    transform: translateY(0) rotate(45deg)
  }

  100% {
    transform: translateY(6px) rotate(0deg)
  }
}

.page__header .menu-icon span {
  position: absolute;
  left: 15px;
  top: 25px;
  left: calc((100% - 20px)/2);
  top: calc((100% - 1px)/2);
  width: 20px;
  height: 2px;
  background-color: rgba(0, 0, 0, .5)
}

.page__header .menu-icon span:nth-child(1) {
  transform: translateY(6px) rotate(0deg)
}

.page__header .menu-icon span:nth-child(3) {
  transform: translateY(-6px) rotate(0deg)
}

.page__header .menu-icon.icon-click span:nth-child(1) {
  animation-duration: .5s;
  animation-fill-mode: both;
  animation-name: clickfirst
}

.page__header .menu-icon.icon-click span:nth-child(2) {
  animation-duration: .2s;
  animation-fill-mode: both;
  animation-name: clickmid
}

.page__header .menu-icon.icon-click span:nth-child(3) {
  animation-duration: .5s;
  animation-fill-mode: both;
  animation-name: clicklast
}

.page__header .menu-icon.icon-out span:nth-child(1) {
  animation-duration: .5s;
  animation-fill-mode: both;
  animation-name: outfirst
}

.page__header .menu-icon.icon-out span:nth-child(2) {
  animation-duration: .2s;
  animation-fill-mode: both;
  animation-name: outmid
}

.page__header .menu-icon.icon-out span:nth-child(3) {
  animation-duration: .5s;
  animation-fill-mode: both;
  animation-name: outlast
}

.page__header .menu-icon:hover span {
  background-color: #000
}

.page__header .search-icon {
  height: 50px;
  width: 50px;
  display: inline-block;
  text-align: center;
  line-height: 50px;
  color: rgba(0, 0, 0, .5);
  cursor: pointer;
  font-size: 2rem
}

.page__header .search-icon:hover {
  color: #000
}