@font-face { font-family: "Alegreya Sans SC"; src: url(../fonts/alegreyasans/AlegreyaSansSC-Regular.otf); }
@font-face { font-family: "Aller light"; src: url(../fonts/Aller/Aller_Lt.ttf); }
@font-face { font-family: "Aller light"; src: url(../fonts/Aller/Aller_Rg.ttf); font-weight: bold; }
@font-face { font-family: "Aller light"; src: url(../fonts/Aller/Aller_LtIt.ttf); font-style: italic; }
@font-face { font-family: "Aller light"; src: url(../fonts/Aller/Aller-It.ttf); font-weight: bold; font-style: italic; }
a { color: black; text-decoration: none; }

* { box-sizing: border-box; }

.hide { display: none !important; }

.category { border-bottom: solid 0.4rem; }

.web { border-bottom-color: #00dcdc; }

.graphics { border-bottom-color: #f9005c; }

.free { border-bottom-color: #f5c500; }

.diy { border-bottom-color: #00b200; }

p.date { color: #a1a1a1; margin-bottom: 0; }
p.date a { color: #a1a1a1; }

body { margin: 0; background: #e6e6e6; font-family: "Aller light"; }
body #wrap { max-width: 1500px; width: 95%; margin: 0 auto; background: white; }
@media screen and (max-width: 40em) { body #wrap { width: 100%; } }

header { width: 100%; font-size: 0; }
header h1 { padding: 0 2.5%; width: 25%; }
header h1 img#logo { width: 100%; padding: 5% 0; }
@media screen and (max-width: 40em) { header h1 { width: 100%; }
  header h1 img#logo { width: 60%; margin: 0 20%; } }
header ul#social { width: 75%; padding: 0; margin: 0; text-align: right; padding-right: 2.5%; }
@media screen and (max-width: 40em) { header ul#social { width: 100%; text-align: center; } }
header ul#social li { list-style: none; font-family: "Alegreya Sans SC"; padding: 1em; font-size: 1.2rem; display: inline-block; }
@media screen and (max-width: 40em) { header ul#social li { font-size: 1.4rem; } }
header > * { display: inline-block; vertical-align: middle; }

#banner { font-size: 0; background: #f4f4f4; border: #d9d9d9 solid 0.05rem; }
#banner > * { display: inline-block; width: 50%; vertical-align: middle; }
@media screen and (max-width: 40em) { #banner > * { display: block; width: 100%; text-align: center; } }
#banner #bannerText { font-size: 1rem; padding: 0 8rem 2rem 0; }
@media screen and (max-width: 40em) { #banner #bannerText { padding: 2rem 5%; } }
@media screen and (max-width: 1300px) { #banner #bannerText { padding: 0 5% 0 0; } }
#banner img { padding: 0 10rem 2rem 10rem; }
@media screen and (max-width: 40em) { #banner img { padding: 0 5rem; } }
@media screen and (max-width: 1300px) { #banner img { height: 100%; padding: 0 5% 5% 5%; } }

nav { font-size: 0; }
nav a { display: inline-block; width: 20%; margin: 0 2.5%; font-size: 1.2rem; font-family: "Alegreya Sans SC"; text-align: center; padding: 0.7em; }

ul.posts { margin: 3%; padding: 0; }
@media screen and (max-width: 40em) { ul.posts { margin: 0; padding: 7.5% 0; } }
ul.posts li { width: 27%; margin: 3%; list-style: none; display: inline-block; background: #f2f2f2; border: solid 0.1em #ececec; border-radius: 0.4em; padding-bottom: 1rem; }
@media screen and (max-width: 40em) { ul.posts li { width: 70%; margin: 7.5% 15%; } }
ul.posts li img { width: 100%; border-top-left-radius: 0.4em; border-top-right-radius: 0.4em; z-index: 0; }
ul.posts li .category { width: 100%; margin-top: -0.25em; z-index: 10; }
ul.posts li h1 { text-align: center; display: block; width: 100%; font-size: 1.05rem; font-weight: normal; }
ul.posts li p.date { text-align: center; padding-top: 1rem; }

article { padding: 5% 20%; font-size: 1.1rem; line-height: 1.8em; }
@media screen and (max-width: 40em) { article { padding: 5% 10%; } }
article h1 { margin-bottom: 0; font-size: 2em; font-style: italic; }
article p.date { margin: 0; font-size: 1rem; }
article h3.category { display: inline-block; font-family: "Alegreya Sans SC"; font-weight: normal; padding: 0.2em 0.5em; border-bottom-width: 0.4rem; margin-bottom: 0; }
article img { width: 100%; }
article .half { width: 45%; display: inline-block; }
article .left { margin-right: 5%; }
article .right { margin-left: 5%; }
article .note { font-size: 0.8em; color: grey; }

footer { background: black; text-align: center; color: #b3b3b3; padding: 0.5%; }
footer p { margin: 0; }
footer .license { display: block; margin: 0.3em auto; }

#error404 { text-align: center; min-height: 80vh; }
#error404 a { display: block; width: 10%; margin: 2rem auto; background: #00baba; padding: 0.5em; color: white; text-decoration: none; font-weight: bold; }
#error404 a:hover { background: #00dcdc; }
