*{
    box-sizing:border-box;
}

html{
    min-height:100%;
    background:#050505;
    overflow-y:auto;
    scrollbar-gutter:stable;
}

body{
    min-height:100vh;
    margin:0;
    color:#eee6d4;
    background:
        radial-gradient(circle at 16% 18%, rgba(128,148,143,.16), transparent 31%),
        radial-gradient(circle at 82% 24%, rgba(154,124,92,.12), transparent 29%),
        linear-gradient(180deg, #050505, #11100d 58%, #060606);
    font-family:Georgia, "Times New Roman", serif;
    letter-spacing:0;
}

body.modal-open{
    overflow-y:auto;
}

a{
    color:#d0b982;
    text-decoration:none;
}

.library-nav{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    font-size:12px;
    letter-spacing:.12em;
}

.library-nav a{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:38px;
    padding:9px 15px;
    border:1px solid rgba(212,188,126,.34);
    background:
        linear-gradient(180deg, rgba(212,188,126,.13), rgba(212,188,126,.035));
    color:#ead9ae;
    box-shadow:0 10px 26px rgba(0,0,0,.22);
    font-family:"Times New Roman", "Cinzel", serif;
}

.library-nav a:hover,
.library-nav a:focus-visible{
    border-color:rgba(212,188,126,.56);
    background:
        linear-gradient(180deg, rgba(212,188,126,.22), rgba(212,188,126,.07));
    color:#fff0c8;
}

.library-header{
    position:sticky;
    top:0;
    z-index:5;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:24px;
    padding:26px clamp(18px, 4vw, 54px);
    border-bottom:1px solid rgba(212,188,126,.17);
    background:rgba(5,5,5,.78);
    backdrop-filter:blur(18px);
}

.library-filter{
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    gap:10px;
    width:min(1280px, 100%);
    margin:0 auto;
    padding:18px clamp(18px, 5vw, 70px) 0;
    color:#9b8a64;
    font-size:12px;
    letter-spacing:.08em;
}

.library-filter select{
    min-height:36px;
    max-width:min(460px, 100%);
    border:1px solid rgba(212,188,126,.28);
    background:rgba(5,5,5,.62);
    color:#ead9ae;
    font-family:"Times New Roman", "Cinzel", serif;
}

.library-filter a{
    padding:8px 12px;
    border:1px solid rgba(212,188,126,.22);
}

.library-kicker{
    margin-bottom:8px;
    color:#9b8a64;
    font-size:12px;
    font-family:"Times New Roman", "Cinzel", serif;
    text-transform:uppercase;
}

h1,
h2{
    margin:0;
    font-weight:normal;
    font-family:"Times New Roman", "Cinzel", serif;
}

h1{
    font-size:clamp(28px, 2vw, 54px);
}

h2{
    color:#f3e5c4;
    font-size:28px;
    line-height:1.25;
}

.fragment-field{
    position:relative;
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(230px, 1fr));
    gap:clamp(2px, 1.2vw, 14px);
    width:min(1280px, 100%);
    min-height:calc(100svh - 118px);
    margin:0 auto;
    padding:clamp(26px, 5vw, 58px) clamp(18px, 5vw, 70px) clamp(18px, 3vw, 42px);
}

.fragment-field::before{
    content:"";
    position:fixed;
    inset:0;
    pointer-events:none;
    background:
        linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.018) 1px, transparent 1px);
    background-size:72px 72px;
    mask-image:radial-gradient(circle at 50% 45%, black, transparent 74%);
}

.fragment-tile{
    position:relative;
    width:100%;
    align-self:start;
    z-index:1;
    border:0;
    margin:calc(var(--scatter-y, 0px) - 8px) var(--scatter-x, 0px) -18px;
    padding:0 0 18px;
    background:transparent;
    color:#d8c9a8;
    font:inherit;
    text-align:left;
    cursor:pointer;
    transform:
        translate(var(--scatter-x, 0px), var(--scatter-y, 0px))
        rotate(var(--scatter-rotate, 0deg));
    transition:transform .68s ease, z-index .01s linear;
}

.fragment-tile:hover,
.fragment-tile:focus-visible{
    z-index:4;
    transform:
        translate(var(--scatter-x, 0px), calc(var(--scatter-y, 0px) - 8px))
        rotate(0deg);
}

.fragment-tile em{
    position:absolute;
    top:12px;
    left:12px;
    z-index:1;
    padding:5px 9px;
    border:1px solid rgba(190,170,122,.2);
    background:rgba(0,0,0,.52);
    color:#968761;
    font-size:11px;
    font-style:normal;
    letter-spacing:.18em;
}

.fragment-tile img{
    display:block;
    width:100%;
    aspect-ratio:16 / 9;
    object-fit:cover;
    filter: grayscale(0.2) contrast(.92) brightness(.8);
    opacity:1;
    border:1px solid rgba(222,199,142,.18);
    box-shadow:0 22px 60px rgba(0,0,0,.46);
    transition:filter .28s ease, opacity .28s ease, transform .28s ease, border-color .28s ease;
}

.fragment-tile:hover img,
.fragment-tile:focus-visible img{
    filter:grayscale(0) contrast(1) brightness(.92);
    opacity:1;
    transform:none;
    border-color:rgba(222,199,142,.42);
}

.fragment-noise{
    cursor:not-allowed;
}

.fragment-noise:hover,
.fragment-noise:focus-visible{
    z-index:1;
    transform:
        translate(var(--scatter-x, 0px), var(--scatter-y, 0px))
        rotate(var(--scatter-rotate, 0deg));
}

.fragment-noise::before{
    content:"";
    position:absolute;
    inset:0 0 40px;
    z-index:1;
    pointer-events:none;
    opacity:.42;
    background-image:
        radial-gradient(circle at 20% 30%, rgba(255,255,255,.16) 0 1px, transparent 1.3px),
        radial-gradient(circle at 70% 60%, rgba(255,255,255,.1) 0 1px, transparent 1.4px),
        linear-gradient(135deg, rgba(255,255,255,.05) 25%, transparent 25% 50%, rgba(255,255,255,.04) 50% 75%, transparent 75%);
    background-size:7px 7px, 11px 11px, 9px 9px;
}

.fragment-noise img,
.fragment-noise:hover img,
.fragment-noise:focus-visible img{
    filter: grayscale(1) contrast(1.15) brightness(.14);
    opacity:.25;
    transform:none;
    border-color:rgba(222,199,142,.11);
}

.fragment-noise span{
    color:#766d59;
}

.fragment-tile span{
    display:block;
    min-height:26px;
    margin-top:8px;
    color:#bba879;
    font-size:14px;
    font-family:"Times New Roman", "Cinzel", serif;
    line-height:1.45;
    overflow-wrap:anywhere;
}

.fragment-noise.fragment-tile span{
    color:#666;
    text-decoration: line-through;
}

.drift-1{
    --scatter-x:-8px;
    --scatter-y:10px;
    --scatter-rotate:-2.6deg;
}

.drift-2{
    --scatter-x:9px;
    --scatter-y:-4px;
    --scatter-rotate:1.9deg;
}

.drift-3{
    --scatter-x:-3px;
    --scatter-y:18px;
    --scatter-rotate:-1.2deg;
}

.drift-4{
    --scatter-x:12px;
    --scatter-y:6px;
    --scatter-rotate:2.8deg;
}

.drift-5{
    --scatter-x:-12px;
    --scatter-y:-2px;
    --scatter-rotate:-2deg;
}

.drift-6{
    --scatter-x:5px;
    --scatter-y:15px;
    --scatter-rotate:1.4deg;
}

.empty-library{
    grid-column:1 / -1;
    align-self:center;
    justify-self:center;
    color:#8b7f66;
    font-size:15px;
}

.paper-library{
    width:min(1040px, 100%);
    margin:0 auto;
    padding:clamp(28px, 5vw, 70px) clamp(18px, 5vw, 58px) 70px;
}

.paper-card{
    position:relative;
    margin:0 0 22px;
    padding:26px;
    border:1px solid rgba(212,188,126,.18);
    background:
        linear-gradient(180deg, rgba(212,188,126,.045), rgba(7,7,6,.76));
    box-shadow:0 20px 70px rgba(0,0,0,.35);
}

.paper-card h2{
    max-width:820px;
    margin-bottom:0;
}

.paper-meta-line{
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    gap:8px;
    margin:0 0 12px;
    color:#9b8a64;
    font-family:"Times New Roman", "Cinzel", serif;
    font-size:13px;
    letter-spacing:.02em;
}

.paper-new-badge{
    display:inline-flex;
    align-items:center;
    min-height:22px;
    padding:2px 8px;
    border:1px solid rgba(160,38,34,.58);
    background:rgba(160,38,34,.14);
    color:#d9a29b;
    text-transform:uppercase;
    font-size:11px;
    letter-spacing:.08em;
}

.paper-card p{
    max-width:780px;
    color:#c9b895;
    line-height:1.8;
}

.paper-card dl{
    max-width:620px;
}

.paper-card-header{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:18px;
    margin-bottom:14px;
}

.paper-locale-toggle{
    display:flex;
    flex:0 0 auto;
    gap:6px;
}

.paper-locale-toggle button{
    min-width:38px;
    min-height:32px;
    padding:7px 9px;
    border:1px solid rgba(212,188,126,.24);
    background:rgba(0,0,0,.16);
    color:#9b8a64;
    font:inherit;
    font-size:12px;
    cursor:pointer;
}

.paper-locale-toggle button.active{
    border-color:rgba(212,188,126,.55);
    background:rgba(212,188,126,.12);
    color:#ead9ae;
}

.fragment-modal[hidden]{
    display:none;
}

.fragment-modal{
    position:fixed;
    inset:0;
    z-index:20;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:24px;
    opacity:0;
    pointer-events:none;
    transition:opacity .28s ease;
}

.fragment-modal.is-visible{
    opacity:1;
    pointer-events:auto;
}

.fragment-modal-backdrop{
    position:absolute;
    inset:0;
    background:rgba(0,0,0,.82);
    backdrop-filter:blur(12px);
    opacity:0;
    transition:opacity .34s ease;
}

.fragment-modal.is-visible .fragment-modal-backdrop{
    opacity:1;
}

.fragment-modal-window{
    position:relative;
    z-index:1;
    display:grid;
    grid-template-columns:minmax(280px, 1.35fr) minmax(280px, .75fr);
    gap:26px;
    width:min(1180px, 100%);
    max-height:88vh;
    padding:22px;
    border:1px solid rgba(222,199,142,.24);
    background:linear-gradient(180deg, rgba(18,17,15,.98), rgba(7,7,6,.98));
    box-shadow:0 34px 100px rgba(0,0,0,.72);
    overflow:hidden;
    opacity:0;
    transform:translateY(18px) scale(.985);
    filter:blur(3px);
    transition:
        opacity .36s ease,
        transform .42s cubic-bezier(.2, .74, .24, 1),
        filter .36s ease;
}

.fragment-modal.is-visible .fragment-modal-window{
    opacity:1;
    transform:translateY(0) scale(1);
    filter:blur(0);
}

.fragment-modal-close{
    position:absolute;
    top:14px;
    right:14px;
    z-index:2;
    width:36px;
    height:36px;
    border:1px solid rgba(222,199,142,.22);
    background:rgba(0,0,0,.28);
    color:#e8d8b0;
    cursor:pointer;
    font-size:22px;
    line-height:1;
}

.fragment-modal-image img{
    display:block;
    width:100%;
    max-height:78vh;
    object-fit:contain;
    background:#090807;
}

.fragment-modal-info{
    max-height:calc(88vh - 44px);
    overflow-y:auto;
    scrollbar-width:thin;
    scrollbar-color:rgba(210,170,90,.28) transparent;
    padding:26px 16px 12px 0;
}

.fragment-modal-info::-webkit-scrollbar{
    width:8px;
}

.fragment-modal-info::-webkit-scrollbar-thumb{
    background:rgba(210,170,90,.24);
}

.fragment-modal-info p{
    color:#c9b895;
    line-height:1.8;
}

dl{
    display:grid;
    grid-template-columns:88px 1fr;
    gap:10px 16px;
    margin:22px 0;
    color:#c7b58e;
    font-size:14px;
}

dt{
    color:#897a5a;
}

dd{
    margin:0;
}

.download-actions{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin:24px 0;
}

.download-actions a,
.library-login button{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:42px;
    padding:11px 16px;
    border:1px solid rgba(212,188,126,.36);
    background:rgba(212,188,126,.06);
    color:#ead9ae;
    font:inherit;
    cursor:pointer;
}

.paper-language-actions{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    margin:24px 0 0;
}

.paper-language-set{
    display:flex;
    align-items:center;
    gap:8px;
    padding:8px;
    border:1px solid rgba(212,188,126,.18);
    background:rgba(0,0,0,.18);
}

.paper-language-set span{
    color:#9b8a64;
    font-size:12px;
    letter-spacing:.12em;
}

.paper-language-set a{
    display:inline-flex;
    align-items:center;
    min-height:34px;
    padding:8px 11px;
    border:1px solid rgba(212,188,126,.34);
    background:rgba(212,188,126,.06);
    color:#ead9ae;
    font-size:12px;
}

.copyright{
    margin-top:24px;
    color:#84775e;
    font-size:12px;
}

.library-login-body{
    display:grid;
    place-items:center;
    padding:24px;
}

.library-login{
    width:min(440px, 100%);
    padding:34px;
    border:1px solid rgba(212,188,126,.22);
    background:rgba(7,7,6,.8);
    box-shadow:0 30px 90px rgba(0,0,0,.52);
}

.library-login p{
    color:#a99a75;
    line-height:1.7;
}

.library-login form{
    margin-top:26px;
}

.library-login-note{
    margin:10px 0 0;
    font-size:13px;
}

.library-language-toggle{
    position:fixed;
    top:20px;
    left:20px;
    z-index:5;
    display:flex;
    gap:6px;
}

.library-language-toggle button{
    min-width:42px;
    min-height:32px;
    border:1px solid rgba(212,188,126,.24);
    background:rgba(0,0,0,.24);
    color:#8f805f;
    font-family:"Times New Roman", "Cinzel", serif;
    letter-spacing:.1em;
    cursor:pointer;
}

.library-language-toggle button:hover,
.library-language-toggle button:focus-visible,
.library-language-toggle button.is-active{
    color:#ead9ae;
    border-color:rgba(212,188,126,.46);
    background:rgba(212,188,126,.08);
}

.library-terminal-return{
    position:fixed;
    top:20px;
    right:20px;
    z-index:5;
    padding:9px 13px;
    border:1px solid rgba(212,188,126,.22);
    background:rgba(0,0,0,.24);
    color:#8f805f;
    font-family:"Times New Roman", "Cinzel", serif;
    font-size:12px;
    letter-spacing:.12em;
    text-align:center;
}

.library-terminal-return:hover,
.library-terminal-return:focus-visible{
    color:#ead9ae;
    border-color:rgba(212,188,126,.46);
    background:rgba(212,188,126,.08);
}

.discord-connect-button{
    display:flex;
    align-items:center;
    justify-content:center;
    width:100%;
    min-height:52px;
    margin:30px 0 10px;
    border:1px solid rgba(212,188,126,.55);
    background:
        linear-gradient(180deg, rgba(212,188,126,.18), rgba(212,188,126,.06));
    box-shadow:
        inset 0 0 0 1px rgba(255,244,210,.05),
        0 16px 38px rgba(0,0,0,.36);
    color:#ead9ae;
    letter-spacing:.13em;
    text-align:center;
    font-family:"Times New Roman", "Cinzel", serif;
}

.discord-connect-button:hover,
.discord-connect-button:focus-visible{
    color:#fff1c9;
    background:
        linear-gradient(180deg, rgba(212,188,126,.26), rgba(212,188,126,.08));
}

.discord-join-button{
    display:flex;
    align-items:center;
    justify-content:center;
    width:100%;
    min-height:42px;
    margin:12px 0 0;
    border:1px solid rgba(212,188,126,.26);
    background:rgba(0,0,0,.18);
    color:#bda978;
    font-size:12px;
    letter-spacing:.12em;
    text-align:center;
    font-family:"Times New Roman", "Cinzel", serif;
}

.discord-join-button:hover,
.discord-join-button:focus-visible{
    border-color:rgba(212,188,126,.46);
    color:#ead9ae;
    background:rgba(212,188,126,.07);
}

.access-key-panel{
    margin-top:26px;
    padding-top:18px;
    border-top:1px solid rgba(212,188,126,.14);
}

.access-key-panel summary{
    cursor:pointer;
    color:#8f805f;
    font-size:12px;
    letter-spacing:.14em;
}

.library-login label{
    display:block;
    margin:20px 0 7px;
    color:#9b8a64;
    font-size:12px;
}

.library-login input{
    width:100%;
    padding:13px;
    border:1px solid rgba(212,188,126,.28);
    background:#090807;
    color:#f2e7cf;
    font:inherit;
}

.library-login button{
    width:100%;
    margin-top:28px;
    min-height:48px;
    border-color:rgba(212,188,126,.55);
    background:
        linear-gradient(180deg, rgba(212,188,126,.16), rgba(212,188,126,.05));
    box-shadow:
        inset 0 0 0 1px rgba(255,244,210,.05),
        0 14px 34px rgba(0,0,0,.34);
    color:#ead9ae;
    letter-spacing:.12em;
    font-family:"Times New Roman", "Cinzel", serif;
}

.library-login button:hover,
.library-login button:focus-visible{
    background:
        linear-gradient(180deg, rgba(212,188,126,.24), rgba(212,188,126,.08));
    color:#fff1c9;
}

.library-error{
    margin:18px 0;
    padding:12px;
    border:1px solid rgba(180,86,70,.34);
    color:#db9d87;
    background:rgba(180,86,70,.08);
}

@media (max-width:800px){
    .library-header{
        align-items:flex-start;
        flex-direction:column;
    }

    .library-nav{
        width:100%;
        gap:8px;
    }

    .library-nav a{
        min-height:36px;
        padding:8px 12px;
    }

    .paper-card-header{
        flex-direction:column;
    }

    .fragment-field{
        grid-template-columns:repeat(auto-fit, minmax(170px, 1fr));
        gap:4px;
        padding:22px 14px 24px;
    }

    .fragment-tile{
        margin:calc(var(--scatter-y, 0px) * .35) calc(var(--scatter-x, 0px) * .25) -10px;
        padding-bottom:12px;
        transform:
            translate(calc(var(--scatter-x, 0px) * .35), calc(var(--scatter-y, 0px) * .35))
            rotate(calc(var(--scatter-rotate, 0deg) * .55));
    }

    .fragment-tile:hover,
    .fragment-tile:focus-visible{
        transform:
            translate(calc(var(--scatter-x, 0px) * .35), calc((var(--scatter-y, 0px) * .35) - 4px))
            rotate(0deg);
    }

    .fragment-tile span{
        min-height:20px;
        margin-top:6px;
        font-size:13px;
    }

    .fragment-modal-window{
        grid-template-columns:1fr;
    }

    .fragment-modal-info{
        padding:0;
    }
}

@media (prefers-reduced-motion:reduce){
    .fragment-modal,
    .fragment-modal-backdrop,
    .fragment-modal-window{
        transition:none;
    }
}
