html { box-sizing: border-box; }

*, *:before, *:after { box-sizing: inherit; }

html, body { height: 100%; }

/** Reset some basic elements */
body, h1, h2, h3, h4, h5, h6, p, blockquote, pre, hr, dl, dd, ol, ul, figure { margin: 0; padding: 0; }

/** Basic styling */
body { font: 400 18px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol"; color: #111; background-color: #ffffff; -webkit-text-size-adjust: 100%; -webkit-font-feature-settings: "kern" 1; -moz-font-feature-settings: "kern" 1; -o-font-feature-settings: "kern" 1; font-feature-settings: "kern" 1; font-kerning: normal; display: flex; min-height: 100vh; flex-direction: column; }

/** Set `margin-bottom` to maintain vertical rhythm */
h1, h2, h3, h4, h5, h6, p, blockquote, pre, ul, ol, dl, figure, .highlight { margin-bottom: 15px; }

/** `main` element */
main { display: block; /* Default value of `display` of `main` element is 'inline' in IE 11. */ }

/** Images */
img { max-width: 100%; vertical-align: middle; }

/** Figures */
figure > img { display: block; }

figcaption { font-size: 15.75px; }

/** Lists */
ul, ol { margin-left: 30px; }

li > ul, li > ol { margin-bottom: 0; }

/** Headings */
h1, h2, h3, h4, h5, h6 { font-family: Georgia, Cambria, "Times New Roman", Times, serif; font-weight: 400; }

/** Links */
a { color: #0e8abe; text-decoration: none; transition: color ease-in 0.1s; }
a:hover { color: #0b688f; text-decoration: underline; }
.social-media-list a:hover { text-decoration: none; }
.social-media-list a:hover .username { text-decoration: underline; }

/** Blockquotes */
blockquote { position: relative; font-family: Georgia, Cambria, "Times New Roman", Times, serif; color: #d9628d; padding-left: 40px; font-size: 20.25px; font-style: italic; }
blockquote > :last-child { margin-bottom: 0; }
blockquote:before { position: absolute; content: open-quote; font-size: 70px; top: 0; left: 0; line-height: 60px; }

/** Code formatting */
pre, code { font-size: 16.875px; border-radius: 3px; background-color: #eee; color: rgba(0, 0, 0, 0.9); font-family: 'Fira Mono', monospace; font-size: 0.9em; }

code { padding: 1px 5px; }

pre { padding: 8px 12px; overflow-x: auto; }
pre > code { border: 0; padding-right: 0; padding-left: 0; }

/** Clearfix */
/** Icons */
.svg-icon { width: 16px; height: 16px; display: inline-block; fill: #828282; vertical-align: text-top; }

.social-media-list li + li { padding-top: 5px; }

/** Tables */
table { margin-bottom: 30px; width: 100%; text-align: left; color: #3f3f3f; border-collapse: collapse; border: 1px solid #e8e8e8; }
table tr:nth-child(even) { background-color: #f7f7f7; }
table th, table td { padding: 10px 15px; }
table th { background-color: #f0f0f0; border: 1px solid #dedede; border-bottom-color: #c9c9c9; }
table td { border: 1px solid #e8e8e8; }

@media print { html, body { width: 210mm; height: 297mm; } }
@page { size: A4; margin: 0; }
body { display: flex; }
body > main { flex: 1 1 auto; }

.wrapper { max-width: 760px; margin-right: auto; margin-left: auto; padding: 0 30px; }
@media screen and (max-width: 800px) { .wrapper { padding: 0 15px; max-width: 100vw; } }

/** Syntax highlighting styles */
.highlight { border-radius: 4px; background: #263238; color: #EEFFFF; box-shadow: 0 1px 8px rgba(0, 0, 0, 0.3); }
.highlight pre, .highlight code { background: transparent; color: inherit; }
.highlighter-rouge .highlight { background: #eef; }
.highlight .c { color: #546E7A; font-style: italic; }
.highlight .err { color: #FF5370; background-color: #e3d2d2; }
.highlight .k { color: #89DDFF; font-weight: bold; }
.highlight .o { color: #C792EA; font-weight: bold; }
.highlight .cm { color: #546E7A; font-style: italic; }
.highlight .cp { color: #546E7A; font-weight: bold; }
.highlight .c1 { color: #546E7A; font-style: italic; }
.highlight .cs { color: #546E7A; font-weight: bold; font-style: italic; }
.highlight .gd { color: #000; background-color: #fdd; }
.highlight .gd .x { color: #000; background-color: #faa; }
.highlight .ge { font-style: italic; }
.highlight .gr { color: #FF5370; }
.highlight .gh { color: #999; }
.highlight .gi { color: #000; background-color: #dfd; }
.highlight .gi .x { color: #000; background-color: #afa; }
.highlight .go { color: #888; }
.highlight .gp { color: #555; }
.highlight .gs { font-weight: bold; }
.highlight .gu { color: #aaa; }
.highlight .gt { color: #FF5370; }
.highlight .kc { color: #f07178; font-weight: bold; }
.highlight .kd { color: #C792EA; font-weight: bold; }
.highlight .kp { color: #C792EA; font-weight: bold; }
.highlight .kr { color: #C792EA; font-weight: bold; }
.highlight .kt { color: #C792EA; font-weight: bold; }
.highlight .m { color: #F78C6C; }
.highlight .s { color: #C3E88D; }
.highlight .na { color: #82AAFF; }
.highlight .nc { color: #FFCB6B; font-weight: bold; }
.highlight .no { color: #FF5370; }
.highlight .ni { color: #800080; }
.highlight .ne { color: #FF5370; font-weight: bold; }
.highlight .nf { color: #FF5370; font-weight: bold; }
.highlight .nn { color: #555; }
.highlight .nt { color: #FF5370; }
.highlight .nv { color: #89DDFF; }
.highlight .ow { font-weight: bold; }
.highlight .w { color: #bbb; }
.highlight .mf { color: #F78C6C; }
.highlight .mh { color: #F78C6C; }
.highlight .mi { color: #F78C6C; }
.highlight .mo { color: #F78C6C; }
.highlight .sb { color: #C3E88D; }
.highlight .sc { color: #C3E88D; }
.highlight .sd { color: #C3E88D; }
.highlight .s2 { color: #C3E88D; }
.highlight .se { color: #C3E88D; }
.highlight .sh { color: #C3E88D; }
.highlight .si { color: #C3E88D; }
.highlight .sx { color: #C3E88D; }
.highlight .sr { color: #009926; }
.highlight .s1 { color: #C3E88D; }
.highlight .ss { color: #C3E88D; }
.highlight .bp { color: #999; }
.highlight .vc { color: #008080; }
.highlight .vg { color: #008080; }
.highlight .vi { color: #008080; }
.highlight .il { color: #099; }

.b-post .page-title { display: block; margin-top: 10px; font-family: Georgia, Cambria, "Times New Roman", Times, serif; font-size: 40px; letter-spacing: 1px; }
.b-post .date { margin-bottom: 30px; font-family: Georgia, Cambria, "Times New Roman", Times, serif; font-style: italic; font-size: 0.9em; color: #d44e7e; }
.b-post .date time { margin-right: 5px; }
.b-post .date .tag { color: #828282; display: inline-block; margin-left: 5px; }
.b-post .materials .material-title { font-style: italic; margin-top: 30px; font-size: 24px; color: #cf396f; }
.b-post .materials .slides-container, .b-post .materials .video-container { position: relative; margin-bottom: 20px; padding-bottom: 53%; padding-top: 25px; height: 0; }
.b-post .materials .slides-container > object, .b-post .materials .slides-container > iframe, .b-post .materials .video-container > object, .b-post .materials .video-container > iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.b-post h2 { margin: 40px 0 0 0; }
.b-post h3 { margin: 30px 0 0 0; }
.b-post p { margin: 20px 0; }
.b-post code { overflow-wrap: break-word; }

.b-base-page { height: 100%; display: flex; flex-direction: column; }
.b-base-page > .header-image { flex: 0 1 auto; height: 20vh; background-size: cover; background-position-x: center; background-position-y: center; }
.b-base-page > .header-image:after { content: ""; display: block; height: 100%; background: linear-gradient(135deg, #0e8abe 0%, #f6e28b 100%); mix-blend-mode: color; }
.b-base-page > .content { flex: 1 1 auto; margin-top: 20px; padding-bottom: 20px; }
.b-base-page > .content .page-title { display: block; margin-top: 10px; font-family: Georgia, Cambria, "Times New Roman", Times, serif; font-size: 40px; line-height: 46px; letter-spacing: 1px; }
.b-base-page footer { flex: 0 1 auto; text-align: center; padding: 30px; background: rgba(0, 0, 0, 0.05); }
.b-base-page footer .wrapper { display: flex; justify-content: space-around; }

.b-main-footer { background: #1c2429; padding: 15px 30px; color: rgba(255, 255, 255, 0.8); }
.b-main-footer a { color: #f6e28b; }
.b-main-footer a:hover { color: #fff; text-decoration: none; }
.b-main-footer .site-title { text-align: center; display: block; margin-bottom: 20px; font-family: Georgia, Cambria, "Times New Roman", Times, serif; font-style: italic; font-size: 26px; }
.b-main-footer .lists { display: flex; align-items: flex-start; justify-content: space-between; flex-wrap: wrap; margin: 20px 0px; }
.b-main-footer .lists .list { border-left: 1px solid rgba(255, 255, 255, 0.4); border-radius: 0 0 0 10px; max-width: 330px; }
.b-main-footer .lists .list .list-title { position: relative; padding-left: 25px; line-height: 26px; letter-spacing: 3px; }
.b-main-footer .lists .list .list-title:after { content: " "; position: absolute; display: block; width: 25px; height: 25px; top: 0; left: -12.5px; border-radius: 50%; background: #1c242a; border-bottom: 1px solid rgba(255, 255, 255, 0.4); }
.b-main-footer .lists .list ul { list-style: none; margin-left: 0; }
.b-main-footer .lists .list ul li { position: relative; padding-left: 25px; margin-bottom: 15px; }
.b-main-footer .lists .list ul li:after { content: " "; position: absolute; display: block; width: 7px; height: 7px; margin-top: 10px; top: 0; left: -4px; border-radius: 50%; background: #f6e28b; }
.b-main-footer .lists .list ul li .article-title { letter-spacing: 1px; margin-bottom: 5px; }
.b-main-footer .lists .list ul li .excerpt { margin-bottom: 5px; font-weight: lighter; font-size: 0.8em; line-height: 1.3em; color: rgba(255, 255, 255, 0.6); }
.b-main-footer .lists .list ul li .date { display: block; font-family: Georgia, Cambria, "Times New Roman", Times, serif; font-style: italic; font-size: 0.8em; color: rgba(246, 226, 139, 0.6); }
.b-main-footer footer { font-size: 0.8em; text-align: center; margin-top: 30px; }

.b-nav-header { height: 40px; flex: 0 0 auto; background: #fff; z-index: 1; box-shadow: 0 4px 6px 0 rgba(0, 0, 0, 0.2); }
.b-nav-header > .wrapper { display: flex; height: 100%; align-items: center; }
.b-nav-header > .wrapper > .site-title { flex: 1 1 auto; height: 100%; padding: 5px 0; }
.b-nav-header > .wrapper > .site-title img { max-height: 100%; }
.b-nav-header > .wrapper > .main-nav > a { font-size: 0.8em; margin-left: 20px; text-transform: uppercase; }

.b-posts-list { list-style: none; margin: 0; }
.b-posts-list > .post { margin-bottom: 40px; }
.b-posts-list > .post > .title { margin-bottom: 5px; font-size: 24px; }
.b-posts-list > .post > .excerpt { margin-bottom: 10px; }
.b-posts-list > .post > .aside { color: #cf396f; font-style: italic; font-size: 0.9em; }
.b-posts-list > .post > .aside > .date { margin-right: 10px; }
.b-posts-list > .post > .aside > .entity, .b-posts-list > .post > .aside > .tag { margin-left: 10px; }
.b-posts-list > .post > .aside > .tag { color: #828282; }

@media print { body[data-page="/resume/"] .b-main-footer, body[data-page="/resume/"] .b-nav-header { display: none; } }
.b-resume { height: 100%; display: flex; align-items: center; padding: 20px 0; background: #d8f1f7; font-size: 9pt; }
.b-resume > .sheet { flex: 0 0 auto; margin: auto; border-radius: 4px; background: #fff; min-height: 297mm; width: min(100%, 210mm); padding: 5mm 8mm; box-shadow: 0 4px 6px 0 rgba(0, 0, 0, 0.2); }
.b-resume > .sheet * { margin: 0; font-family: Verdana, Geneva, Tahoma, sans-serif; }
.b-resume > .sheet > .title .me { display: flex; align-items: center; }
.b-resume > .sheet > .title .me > .name { font-family: Georgia, "Times New Roman", Times, serif; flex: 1 1 auto; font-size: 3.5em; line-height: 1em; margin: 0; }
.b-resume > .sheet > .title .me > .name > .surname { font-family: Georgia, "Times New Roman", Times, serif; color: #828282; font-style: italic; }
.b-resume > .sheet > .title .me > .portrait { max-height: 20mm; border-radius: 50%; }
.b-resume > .sheet > .title > .footer { font-size: .9em; margin-top: -9pt; }
.b-resume > .sheet > .title > .footer > a { margin-right: 4mm; color: #0e8abe; }
.b-resume > .sheet > .title > .footer > a .svg-icon { height: 3mm; width: 3mm; fill: #41bdf1; }
.b-resume > .sheet > .title > .footer > a:hover { text-decoration: none; }
.b-resume > .sheet > .section-title { font-family: Georgia, "Times New Roman", Times, serif; display: flex; align-items: baseline; margin: 2mm 0 2mm 0; color: #111; }
.b-resume > .sheet > .section-title > .line { flex: 1; margin-left: 1mm; border-bottom: 0.3mm solid #111; }
.b-resume > .sheet > .experience > .job { display: flex; align-items: flex-start; margin-bottom: 2mm; }
.b-resume > .sheet > .experience > .job > .logo-wrapper { flex: 0 0 auto; width: 10mm; height: 10mm; display: flex; align-items: center; justify-content: center; }
.b-resume > .sheet > .experience > .job > .logo-wrapper > .logo { max-width: 100%; max-height: 100%; }
.b-resume > .sheet > .experience > .job > .text { flex: 1 1 auto; margin-left: 4mm; }
.b-resume > .sheet > .experience > .job > .text > .header { display: flex; margin-bottom: 1mm; }
.b-resume > .sheet > .experience > .job > .text > .header > .title { flex: 1 1 auto; }
.b-resume > .sheet > .experience > .job > .text > .header > .title > .company { font-family: Georgia, "Times New Roman", Times, serif; font-weight: bold; font-size: 1.1em; color: #111; }
.b-resume > .sheet > .experience > .job > .text > .header > .title > .position { color: #5e5e5e; }
.b-resume > .sheet > .experience > .job > .text > .header .location { font-size: .8em; text-align: right; font-style: italic; color: #0e8abe; margin-bottom: 1mm; }
.b-resume > .sheet > .experience > .job > .text > .header .period { font-size: .8em; text-align: right; font-style: italic; color: #5e5e5e; }
.b-resume > .sheet > .experience > .job > .text > .content { color: #5e5e5e; font-size: .9em; }
.b-resume > .sheet > .experience > .job > .text > .content > ul { padding-left: 20px; margin-bottom: 2mm; }
.b-resume > .sheet > .experience > .job > .text > .content > ul em { color: #111; }
.b-resume > .sheet > .archived { display: flex; justify-content: space-around; }
.b-resume > .sheet > .archived > .job { text-align: center; }
.b-resume > .sheet > .archived > .job > .logo-wrapper { width: 100%; height: 7mm; display: flex; align-items: center; justify-content: center; padding-bottom: 1mm; }
.b-resume > .sheet > .archived > .job > .logo-wrapper > .logo { max-width: 100%; max-height: 100%; }
.b-resume > .sheet > .archived > .job > .company { font-family: Georgia, "Times New Roman", Times, serif; font-weight: bold; color: #444444; }
.b-resume > .sheet > .archived > .job > .position { font-size: .95em; color: #444444; }
.b-resume > .sheet > .archived > .job > .period { font-size: .8em; font-style: italic; color: #777777; }
.b-resume > .sheet > .education > .study { display: flex; align-items: flex-start; }
.b-resume > .sheet > .education > .study > .logo-wrapper { width: 10mm; height: 10mm; display: flex; align-items: center; justify-content: center; }
.b-resume > .sheet > .education > .study > .logo-wrapper > .logo { max-width: 100%; max-height: 100%; }
.b-resume > .sheet > .education > .study > .title { flex: 1 1 auto; margin-left: 4mm; }
.b-resume > .sheet > .education > .study > .title > .entity { font-family: Georgia, "Times New Roman", Times, serif; font-weight: bold; font-size: 1.1em; color: #111; }
.b-resume > .sheet > .education > .study > .title > .qualification { color: #5e5e5e; }
.b-resume > .sheet > .education > .study .location { font-size: .8em; text-align: right; font-style: italic; color: #0e8abe; margin-bottom: 1mm; }
.b-resume > .sheet > .education > .study .period { font-size: .8em; text-align: right; font-style: italic; color: #5e5e5e; }
.b-resume > .sheet > .talks > .talk { display: flex; align-items: center; margin-bottom: 0.1mm; }
.b-resume > .sheet > .talks > .talk > .logo-wrapper { width: 10mm; height: 3mm; padding: 0 2mm; display: flex; align-items: center; justify-content: center; }
.b-resume > .sheet > .talks > .talk > .logo-wrapper > .logo { max-width: 100%; max-height: 100%; }
.b-resume > .sheet > .talks > .talk > .title { flex: 1 1 auto; margin: 0 4mm; font-size: .9em; font-weight: bold; color: #444444; }
.b-resume > .sheet > .talks > .talk > .title a { color: inherit; }
.b-resume > .sheet > .talks > .talk > .title .entity { font-weight: normal; font-style: italic; color: #5e5e5e; }
.b-resume > .sheet > .talks > .talk > .location { font-size: .8em; font-style: italic; color: #0e8abe; }
.b-resume > .sheet > .talks > .talk > .location > .date { color: #5e5e5e; }
.b-resume > .sheet > .side-projects > .project { display: flex; align-items: center; margin-bottom: 0.1mm; }
.b-resume > .sheet > .side-projects > .project > .logo-wrapper { width: 10mm; height: 3mm; padding: 0 2mm; display: flex; align-items: center; justify-content: center; }
.b-resume > .sheet > .side-projects > .project > .logo-wrapper > .logo { max-width: 100%; max-height: 100%; }
.b-resume > .sheet > .side-projects > .project > .name { flex: 1 1 auto; margin: 0 4mm; font-size: .9em; font-weight: bold; color: #444444; }
.b-resume > .sheet > .side-projects > .project > .name a { color: inherit; }
.b-resume > .sheet > .side-projects > .project > .name .description { font-weight: normal; font-style: italic; color: #5e5e5e; }
.b-resume > .sheet > .side-projects > .project > .name .description em { color: #111; }
.b-resume > .sheet > .side-projects > .project > .year { font-size: .8em; font-style: italic; color: #5e5e5e; }

@media screen and (max-width: 600px) { .b-resume > .sheet > .experience > .job { flex-direction: column; }
  .b-resume > .sheet > .experience > .job > .logo-wrapper { display: none; }
  .b-resume > .sheet > .experience > .job > .text { margin-left: 0; }
  .b-resume > .sheet > .title .me .name { font-size: 2.5em; margin-bottom: .5em; }
  .b-resume > .sheet > .title .me .name .surname { display: block; }
  .b-resume > .sheet > .title > .footer > a { display: block; }
  .b-resume > .sheet > .education > .study > .logo-wrapper { display: none; }
  .b-resume > .sheet > .education > .study > .title { margin-left: 0; }
  .b-resume > .sheet > .archived { flex-direction: column; align-items: flex-start; }
  .b-resume > .sheet > .archived > .job { text-align: left; margin-bottom: 1em; }
  .b-resume > .sheet > .archived > .job > .logo-wrapper { display: none; }
  .b-resume > .sheet > .talks > .talk { flex-direction: column; align-items: flex-start; margin-bottom: 1em; }
  .b-resume > .sheet > .talks > .talk .logo-wrapper { display: none; }
  .b-resume > .sheet > .talks > .talk .title { margin: 0; }
  .b-resume > .sheet > .talks > .talk .title .entity { display: block; }
  .b-resume > .sheet > .side-projects > .project { margin-bottom: 1em; }
  .b-resume > .sheet > .side-projects > .project .name { margin: 0; }
  .b-resume > .sheet > .side-projects > .project .name .description { display: block; }
  .b-resume > .sheet > .side-projects > .project .logo-wrapper, .b-resume > .sheet > .side-projects > .project .year { display: none; } }
@media print { .b-resume { padding: 0; }
  .b-resume > .sheet { box-shadow: none; }
  .page-break { height: 8mm; page-break-before: always; } }
.e-twitter-share { font-size: 0.9em; border: 1px solid #1da1f2; border-radius: 20px; padding: 4px 10px; color: #1da1f2; transition: background ease-in 0.2s; }
.e-twitter-share .svg-icon { fill: #1da1f2; }
.e-twitter-share:hover { text-decoration: none; color: #1da1f2; background: rgba(255, 255, 255, 0.9); }

.e-github-edit { font-size: 0.9em; border: 1px solid #24292e; border-radius: 20px; padding: 4px 10px; color: #24292e; transition: background ease-in 0.2s; }
.e-github-edit .svg-icon { fill: #24292e; }
.e-github-edit:hover { text-decoration: none; color: #24292e; background: rgba(255, 255, 255, 0.9); }
