
@import "https://cdn.jsdelivr.net/gh/highlightjs/cdn-release@11.0.0/build/styles/github-dark.min.css";
/* Code syntax highlight */
.body-disclaimer {
    display: flex;
    flex-direction: column;
    align-items: center;
}
.body-disclaimer p {
    width: 50%;
}
@media screen and (max-width: 480px) {
    .body-disclaimer p {
        width: 95%;
    }
}
.body-exploit {
    margin: 0 auto;
    width: 100%;
    height: 100%;
    box-sizing: border-box;
}
.body-exploit .container {
    width: 100%;
    height: 100%;
    display: grid;
    grid-template-columns: 1fr minmax(60%, 800px) 1fr;
}
/* Header */
.body-exploit .container header {
    display: none;
    flex-direction: column;
    align-items: center;
}
.body-exploit .container header #title {
    margin: 0 0 4px 0;
    text-align: center;
    font-family: var(--font-family-logo);
    font-size: 0.95em;
    font-weight: bold;
    color: var(--color-white-tl);
    text-decoration: none;
}
/* Side  */
.body-exploit .container .side {
    box-sizing: border-box;
    top: 0;
    margin: 0;
    width: 100%;
    height: 90vh;
}
.body-exploit .container .side .inner {
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    padding: 12px 24px;
    overflow-y: auto;
}
.body-exploit .container .side .inner::-webkit-scrollbar {
    width: 5px;
}
.body-exploit .container .side .inner::-webkit-scrollbar-track {
    background: none;
}
.body-exploit .container .side .inner::-webkit-scrollbar-thumb {
    background: var(--color-navy-light-super);
}
.body-exploit .container .side .inner .block {
    margin: 12px 0;
}
.body-exploit .container .side .inner .block .head {
    margin: 0;
    color: var(--color-white-tl);
    font-size: 1.2em;
}
/* Side left */
.body-exploit .container .side-left .header {
    box-sizing: border-box;
    width: 100%;
    padding: 4px;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.body-exploit .container .side-left .header .title {
    margin: 4px 0 8px 0;
    font-family: var(--font-family-logo);
    font-size: 1.2em;
    font-weight: bold;
    color: var(--color-white);
    text-decoration: none;
}
.body-exploit .container .side-left .header #search {
    width: 100%;
}
.body-exploit .container .side-left .header #search .pagefind-ui__form::before {
    display: block;
    top: 10px;
}
.body-exploit .container .side-left .header #search .pagefind-ui__search-input {
    z-index: 2;
    /* height: 40px; */
    padding: 8px 8px 8px 38px;
    background: var(--color-navy-light-super);
    border: none;
    border-radius: 4px;
    outline: none;
    color: var(--color-white);
    --pagefind-ui-scale: 0.6;
}
.body-exploit .container .side-left .header #search .pagefind-ui__search-input::-moz-placeholder {
    opacity: 0.6;
}
.body-exploit .container .side-left .header #search .pagefind-ui__search-input::placeholder {
    opacity: 0.6;
}
.body-exploit .container .side-left .header #search .pagefind-ui__search-input:focus {
    outline: 1.2px solid var(--color-red);
    filter: drop-shadow(0 0 0.1em var(--color-red));
}
.body-exploit .container .side-left .header #search .pagefind-ui__drawer {
    position: absolute;
    z-index: 1;
    top: 32px;
    width: 100%;
    max-height: 60vh;
    background-color: var(--color-navy-light-super);
    border-radius: 0 0 8px 8px;
    overflow-x: hidden;
    overflow-y: scroll;
    transition: visibility 0s, opacity 0.1s linear;
}
.body-exploit .container .side-left .header #search .pagefind-ui__drawer::-webkit-scrollbar {
    width: 5px;
}
.body-exploit .container .side-left .header #search .pagefind-ui__drawer::-webkit-scrollbar-track {
    background: none;
}
.body-exploit .container .side-left .header #search .pagefind-ui__drawer::-webkit-scrollbar-thumb {
    background: var(--color-white-tl-super);
}
.body-exploit .container .side-left .header #search .pagefind-ui__results-area {
    padding: 12px;
}
.body-exploit .container .side-left .header #search .pagefind-ui__message {
    padding: 4px 0 16px 0;
    font-size: 0.8em;
    color: var(--color-white-tl);
}
.body-exploit .container .side-left .header #search .pagefind-ui__result {
    padding: 8px 0;
    border-color: var(--color-white-tl-super);
    border-width: 0.1em;
}
.body-exploit .container .side-left .header #search .pagefind-ui__result-title {
    line-height: 1.1em;
}
.body-exploit .container .side-left .header #search .pagefind-ui__result-title a {
    color: var(--color-red);
    font-size: 0.9em;
}
.body-exploit .container .side-left .header #search .pagefind-ui__result-excerpt {
    display: none;
}
.body-exploit .container .side-left .header #search .pagefind-ui__button {
    border-color: var(--color-white-tl);
    color: var(--color-white-tl);
}
.body-exploit .container .side-left .header #search .pagefind-ui__button:hover {
    border-color: var(--color-white);
    color: var(--color-white);
}
.body-exploit .container .side-left .inner .related {
    display: flex;
    flex-direction: column;
}
.body-exploit .container .side-left .inner .related .head {
    font-size: 1.1em;
}
.body-exploit .container .side-left .inner .related .item {
    margin: 12px 0 4px 0;
    border-bottom: 2px solid var(--color-navy-light-super);
    padding: 6px 4px;
    font-size: 1em;
    color: var(--color-white-tl);
}
.body-exploit .container .side-left .inner .related .page {
    padding: 8px 4px;
    transition: 0.1s;
    font-size: 0.85em;
    line-height: 1.6em;
}
.body-exploit .container .side-left .inner .related .page:hover {
    background-color: var(--color-navy-light);
}
.body-exploit .container .side-left .inner .related .page span {
    color: var(--color-white);
}
.body-exploit .container .side-left .inner .related .page a {
    color: var(--color-red);
    text-decoration: none;
}
.body-exploit .container .side-left .inner .related .page a:hover {
    text-decoration: underline;
}
/* Side right */
.body-exploit .container .side-right .header {
    box-sizing: border-box;
    width: 100%;
}
.body-exploit .container .side-right .header .socials {
    box-sizing: border-box;
    width: 100%;
    border-bottom: 2px solid var(--color-navy-light-super);
    padding: 8px;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-end;
}
.body-exploit .container .side-right .header .socials a {
    margin: 0 4px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.body-exploit .container .side-right .header .socials a img {
    width: 32px;
    opacity: 0.8;
}
.body-exploit .container .side-right .header .socials a img:hover {
    opacity: 1;
}
.body-exploit .container .side-right .inner .tools .head {
    margin: 0 0 16px 0;
}
.body-exploit .container .side-right .inner .tools .wrapper .item a {
    font-size: 0.9em;
    font-weight: bold;
    text-decoration: none;
    color: var(--color-red);
}
.body-exploit .container .side-right .inner .tools .wrapper .item a:hover {
    text-decoration: underline;
}
.body-exploit .container .side-right .inner .tools .wrapper .item p {
    margin: 0 0 0 8px;
    font-size: 0.8em;
}
/* Article */
.body-exploit .container .article-wrapper {
    width: 100%;
    height: 100vh;
    overflow-y: auto;
    box-sizing: border-box;
}
.body-exploit .container .article-wrapper::-webkit-scrollbar {
    width: 5px;
}
.body-exploit .container .article-wrapper::-webkit-scrollbar-track {
    background: none;
}
.body-exploit .container .article-wrapper::-webkit-scrollbar-thumb {
    background: var(--color-navy-light-super);
}
.body-exploit .container .article-wrapper article {
    width: 100%;
    padding: 0 24px;
    box-sizing: border-box;
}
/* Title */
.body-exploit .container .article-wrapper article .exploit-title {
    margin: 0px;
}
/* Date */
.body-exploit .container .article-wrapper article .exploit-date {
    margin: 0 0 24px 0;
    font-size: 0.9em;
}
/* Tags */
.body-exploit .container .article-wrapper article .exploit-tags {
    margin: 4px 0 24px 0;
}
.body-exploit .container .article-wrapper article .exploit-tags .exploit-tag {
    background-color: var(--color-red);
    border-radius: 6px;
    padding: 6px 10px;
    font-size: 0.9em;
    font-weight: bold;
    color: var(--color-white);
}
/* Description */
.body-exploit .container .article-wrapper article .exploit-description {
    margin: 32px 0;
}
/* Content */
.body-exploit .container .article-wrapper article .exploit-content {
    margin: 48px 0;
    width: 100%;
}
.body-exploit .container .article-wrapper article .exploit-content h2 {
    border-bottom: 1.5px dashed var(--color-white-tl-super);
}
.body-exploit .container .article-wrapper article .exploit-content a {
    color: var(--color-red);
}
/* References */
.body-exploit .container .article-wrapper article .exploit-refs {
    margin-top: 120px;
}
.body-exploit .container .article-wrapper article .exploit-refs h2 {
    border-bottom: 1.5px dashed var(--color-white-tl);
}
/* Media query */
@media screen and (max-width: 1024px) {
    .body-exploit .container {
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    .body-exploit .container header {
        display: flex;
    }
    .body-exploit .container .side {
        display: none;
    }
}
@media screen and (max-width: 480px) {
    .body-exploit .container .article-wrapper {
        width: 100%;
        height: 100%;
        padding: 0;
    }
    .body-exploit .container .article-wrapper article {
        padding: 0;
    }
}
footer {
    width: 100vw;
    min-height: 42px;
    background-color: var(--color-navy-light);
    padding: 24px 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
footer .footer-inner {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
footer .footer-inner .footer-upper {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    margin-bottom: 12px;
}
footer .footer-inner .footer-upper div {
    margin: 0 16px;
}
footer .footer-inner .footer-upper .footer-socials {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
}
footer .footer-inner .footer-upper .footer-socials a {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}
footer .footer-inner .footer-upper .footer-socials a img {
    margin-right: 4px;
    width: 24px;
}
footer .footer-inner .footer-upper .footer-socials a span {
    margin-left: 4px;
    font-size: 1.1em;
}
footer .footer-inner .footer-lower .footer-creator {
    margin-top: 12px 0;
}
header {
    width: 100vw;
    position: sticky;
    background-color: var(--color-navy-dark);
    top: 0;
    padding: 16px 8px;
    z-index: 2;
    box-sizing: border-box;
}
header .header-inner {
    margin: 0 auto;
    width: 60%;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-around;
}
/* Title */
header .header-inner #title {
    flex-grow: 0.1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}
header .header-inner #title span {
    font-family: var(--font-family-logo);
    font-weight: bold;
    font-size: 1.1em;
    color: var(--color-white);
    line-height: 0.9em;
    letter-spacing: -0.05em;
}
/* Search */
header .header-inner #search {
    --pagefind-ui-scale: 0.65;
    flex-grow: 1;
}
header .header-inner #search form::before {
    background-color: var(--color-white)!important;
}
header .header-inner #search form input {
    z-index: 2;
    background-color: var(--color-navy-light-super);
    border: none;
    outline: none;
    font-family: var(--font-family-basic);
    font-size: 1.1em;
    color: var(--color-white);
    filter: drop-shadow(0 20px 10px var(--color-navy-tl));
    transition: 0.1s;
}
header .header-inner #search form input:focus {
    outline: 2px solid var(--color-red);
    filter: drop-shadow(0 0 0.2em var(--color-red));
}
header .header-inner #search .pagefind-ui__drawer {
    position: absolute;
    z-index: 1;
    top: 32px;
    width: 100%;
    max-height: 60vh;
    background-color: var(--color-navy-light-super);
    border-radius: 0 0 8px 8px;
    overflow-x: hidden;
    overflow-y: scroll;
    transition: visibility 0s, opacity 0.1s linear;
}
header .header-inner #search .pagefind-ui__drawer::-webkit-scrollbar {
    width: 5px;
}
header .header-inner #search .pagefind-ui__drawer::-webkit-scrollbar-track {
    background: none;
}
header .header-inner #search .pagefind-ui__drawer::-webkit-scrollbar-thumb {
    background: var(--color-white-tl-super);
}
header .header-inner #search .pagefind-ui__drawer .pagefind-ui__results-area {
    padding: 12px;
}
header .header-inner #search .pagefind-ui__drawer .pagefind-ui__message {
    font-size: 0.8em;
    color: var(--color-white);
}
header .header-inner #search .pagefind-ui__drawer .pagefind-ui__result {
    height: 160px;
    border-color: var(--color-white-tl);
    border-width: 0.1em;
}
header .header-inner #search .pagefind-ui__drawer .pagefind-ui__result .pagefind-ui__result-inner {
    height: 100%;
}
header .header-inner #search .pagefind-ui__drawer .pagefind-ui__result .pagefind-ui__result-inner .pagefind-ui__result-title {
}
header .header-inner #search .pagefind-ui__drawer .pagefind-ui__result .pagefind-ui__result-inner .pagefind-ui__result-title .pagefind-ui__result-link {
    font-size: 1.2em;
    color: var(--color-red);
}
header .header-inner #search .pagefind-ui__drawer .pagefind-ui__result .pagefind-ui__result-inner .pagefind-ui__result-excerpt {
    height: 100%;
    font-size: 0.9em;
    line-height: 1.6em;
    color: var(--color-white-tl);
    overflow-y: hidden;
    webkit-line-clamp: 3;
}
header .header-inner #search .pagefind-ui__drawer .pagefind-ui__result .pagefind-ui__result-excerpt mark {
    background: none;
    color: var(--color-white);
    font-weight: bold;
}
header .header-inner #search .pagefind-ui__drawer p.pagefind-ui__result-excerpt iframe,
header .header-inner #search .pagefind-ui__drawer p.pagefind-ui__result-excerpt img,
header .header-inner #search .pagefind-ui__drawer p.pagefind-ui__result-excerpt input,
header .header-inner #search .pagefind-ui__drawer p.pagefind-ui__result-excerpt script
{
    display: none;
}
header .header-inner #search .pagefind-ui__drawer .pagefind-ui__button {
    background-color: var(--color-navy-light-super);
    filter: brightness(1.5);
    border: none;
    font-size: 0.85em;
    font-weight: normal;
    color: var(--color-white-tl);
}
header .header-inner #search .pagefind-ui__drawer .pagefind-ui__button:hover {
    filter: brightness(2);
}
/* Social links */
header .header-inner #socials {
    margin-left: 8px;
    display: flex;
    flex-direction: row;
    align-items: center;
}
header .header-inner #socials a {
    margin: 0 6px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
header .header-inner #socials a img {
    font-size: 0.7em;
    height: 36px;
}
/* Media query */
@media screen and (max-width: 480px) {
    header {
        padding: 12px 12px;
    }
    header .header-inner {
        width: 100%;
        flex-direction: column;
    }
    header .header-inner #title {
        /* display: none; */
        margin-bottom: 8px;
        flex-direction: row;
    }
    header .header-inner #title span {
        margin: 0 4px;
    }
    header .header-inner #search {
        width: 100%;
    }
    header .header-inner #socials {
        display: none;
    }
}
.body-index {
    box-sizing: border-box;
    margin: 12px auto;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
}
/* Site title */
.body-index #title {
    font-family: var(--font-family-logo);
    font-size: 2.2em;
}
/* Site description */
.body-index #description {
    font-size: 1.2em;
}
/* Links */
.body-index #links {
    margin: 6px auto;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
}
.body-index #links a {
    margin: 0 8px;
    text-decoration: none;
}
.body-index #links a img {
    height: 42px;
}
/* Exploits */
.body-index #exploits {
    margin: 32px auto;
    width: 90%;
    max-width: 1200px;
    -moz-column-width: 260px;
         column-width: 260px;
    -moz-column-gap: 12px;
         column-gap: 12px;
    column-count: 3;
    -moz-column-count: 3;
    -webkit-column-count: 3;
    justify-content: space-between;
}
.body-index #exploits .block {
    box-sizing: border-box;
    margin: 0 2px 12px;
    display: inline-block;
    width: 100%;
    background: var(--color-navy-light);
    border-radius: 12px;
    padding: 14px 28px 15px;
}
.body-index #exploits .block.gray {
    border-top: 3px solid #888888;
}
.body-index #exploits .block.red {
    border-top: 3px solid #af3822;
}
.body-index #exploits .block.brown {
    border-top: 3px solid #9a6822;
}
.body-index #exploits .block.orange {
    border-top: 3px solid #cb5f14;
}
.body-index #exploits .block.yellow {
    border-top: 3px solid #868613;
}
.body-index #exploits .block.lime {
    border-top: 3px solid #589e5a;
}
.body-index #exploits .block.green {
    border-top: 3px solid #18ae8a;
}
.body-index #exploits .block.cyan {
    border-top: 3px solid #1374a6;
}
.body-index #exploits .block.blue {
    border-top: 3px solid #1344b9;
}
.body-index #exploits .block.purple {
    border-top: 3px solid #c942ae;
}
.body-index #exploits .block .category {
    margin: 6px 0 12px 0;
    border-bottom: solid 1.5px var(--color-white-tl-super);
    font-size: 1.6em;
    font-weight: bold;
    color: var(--color-white);
}
.body-index #exploits .block .subcategory {
    margin: 10px 0 4px 0;
    font-size: 1.2em;
    font-weight: bold;
    color: var(--color-white-tl);
}
.body-index #exploits .block ul {
    display: flex;
    flex-direction: column;
}
.body-index #exploits .block ul li {
    margin: 6px 0;
    list-style: square;
}
.body-index #exploits .block ul li a {
    color: var(--color-red);
    font-size: 0.9em;
    text-decoration: none;
    line-height: 1.2em;
}
.body-index #exploits .block ul li a:hover {
    text-decoration: underline;
}
/* Media query */
@media screen and (max-width: 480px) {
    .body-index {
        width: 95%;
    }
    .body-index #exploits {
        width: 100%;
        -moz-column-width: initial;
             column-width: initial;
        -moz-column-gap: initial;
             column-gap: initial;
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    .body-index #exploits .block {
        margin: 8px 0;
        display: initial;
        width: 90%;
    }
}
/* Search drawer background */
#search-drawer-bg {
    z-index: 1;
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: rgba(0,0,0,0.5);
}
/* toc - capture tools */
.header-anchor {
    color: var(--color-white)!important;
    text-decoration: none;
}
.body-404 {
    margin: 32px auto;
    width: 50%;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.body-404 p a {
    color: var(--color-red);
}
:root {
    --color-black: #000000;
    --color-navy: #081624;
    --color-navy-tl: rgba(48,20,48,0.5);
    --color-navy-dark: #031018;
    --color-navy-light: #1a1d2f;
    --color-navy-light-super: #29283e;
    --color-red: #e04747;
    --color-red-light: #952d31;
    --color-pink: #db6efe;
    --color-pink-dark: #ab4ede;
    --color-gold: #865a13;
    --color-green: #125310;
    --color-grey: #ededed;
    --color-khaki:#f0e68c;
    --color-white: #efefef;
    --color-white-tl-little: rgba(255,255,255,0.7);
    --color-white-tl: rgba(255,255,255,0.5);
    --color-white-tl-super: rgba(255,255,255,0.2);

    /* font */
    --font-family-basic: sans-serif;
    --font-family-logo: courier;

    /* Pagefind UI */
    --pagefind-ui-scale: 0.8;
    --pagefind-ui-primary: #034ad8;
    --pagefind-ui-text: var(--color-white);
    --pagefind-ui-background: var(--color-navy-light-super);
    --pagefind-ui-border: var(--color-grey);
    --pagefind-ui-tag: var(--color-grey);
    --pagefind-ui-border-width: 1.5px;
    --pagefind-ui-border-radius: 8px;
    --pagefind-ui-image-border-radius: 8px;
    --pagefind-ui-image-box-ratio: 3 / 2;
    --pagefind-ui-font: var(--font-family-basic);
}
html,body {
    width: 100vw;
    min-height: 100vh;
    margin: 0;
    padding: 0;
    overflow-x: hidden;
}
html::-webkit-scrollbar {
    width: 5px;
}
html::-webkit-scrollbar-track {
    background: none;
}
html::-webkit-scrollbar-thumb {
    background: var(--color-navy-light-super);
}
body {
    background-color: var(--color-navy);
    font-family: var(--font-family-basic);
    font-size: 17px;
    color: var(--color-white-tl-little);
    line-height: 1.8em;
}
h1,h2,h3,h4 {
    line-height: 1.2em;
}
h1 { font-size: 2.8em; color: var(--color-white); }
h2 { font-size: 2.0em; color: var(--color-white); }
h3 { font-size: 1.4em; color: var(--color-white); }
h4 { font-size: 1.2em; }
a:link,a:visited {
    color: var(--color-red);
    filter: brightness(1.4);
}
strong {
    color: var(--color-white);
}
pre code {
    font-size: 0.95em;
}
pre code::-webkit-scrollbar {
    width: 10px;
    height: 5px;
}
pre code::-webkit-scrollbar-track {
    background: none;
}
pre code::-webkit-scrollbar-thumb {
    background: var(--color-white-tl-super);
}
/* Overwrite Highlight JS */
.hljs {
    background: var(--color-navy-light-super);
    border-radius: 12px;
    color: var(--color-white);
}
ol,ul {
    padding-left: 18px;
}
main {
    min-height: 100vh;
    padding: 16px;
}
hr {
    border: 1.4px solid var(--color-white-tl-super);
}
@media screen and (max-width: 480px) {
    ol,ul {
        padding-left: 12px;
    }
}