*{box-sizing:border-box}

:root{
    --site-width:580px;
}

html,body{
    margin:0;
    padding:0;
    background:#050505;
    color:#e6e6e6;
    font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;
    font-size:14px;
    line-height:1.5;
}

body{padding:32px}

a{color:#f4f4f4;text-decoration:none}
a:hover{text-decoration:underline}

#header,
#page{
    width:100%;
    max-width:var(--site-width);
    margin-left:auto;
    margin-right:auto;
}

#header{
    margin-top:0;
    margin-bottom:38px;
    border-bottom:1px solid #222;
    padding-bottom:18px;
}

.logo a{
    display:inline-block;
    color:#fff;
    font-size:24px;
    letter-spacing:4px;
    font-weight:700;
    margin-bottom:12px;
}

.filter{
    color:#777;
    font-size:11px;
    letter-spacing:2px;
    text-transform:uppercase;
}

.filter span{color:#333;padding:0 8px}

.intro{
    max-width:100%;
    margin-bottom:34px;
    color:#b8b8b8;
}

.intro p{margin:0 0 12px 0}

.section-title{
    color:#777;
    font-size:11px;
    letter-spacing:3px;
    margin:30px 0 12px 0;
    text-transform:uppercase;
}

input,
select,
textarea{
    width:100%;
    font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;
    background:#050505;
    color:#f0f0f0;
    border:1px solid #252525;
    padding:9px 10px;
    font-size:13px;
    outline:none;
    border-radius:0;
}

textarea{resize:vertical}

button,
.button{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    height:34px;
    min-height:34px;
    padding:0 14px;
    background:#ffffff;
    color:#000000;
    border:none;
    font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;
    font-size:10px;
    font-weight:600;
    letter-spacing:1.2px;
    text-transform:uppercase;
    cursor:pointer;
    transition:opacity .15s ease;
    text-decoration:none;
}

button:hover,
.button:hover{
    opacity:.82;
    color:#000000;
    text-decoration:none;
}

.form-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:12px;
    margin-bottom:12px;
}

label{
    display:block;
    color:#777;
    font-size:11px;
    letter-spacing:2px;
    text-transform:uppercase;
    margin-bottom:12px;
}

label input,
label select,
label textarea{margin-top:6px}

.checkbox-line{
    display:flex;
    align-items:center;
    gap:10px;
    color:#aaa;
    margin-top:14px;
}

.checkbox-line input{
    width:auto;
    margin:0;
}

.request-actions{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin-top:16px;
}

.small{
    color:#999;
    font-size:13px;
    max-width:100%;
    margin-bottom:16px;
}

.notice{
    border-top:1px solid #222;
    border-bottom:1px solid #222;
    margin-top:42px;
    padding:6px 0 20px 0;
    max-width:100%;
}

.notice p{
    margin:0 0 6px 0;
    color:#aaa;
}

.portal-grid{
    display:grid;
    grid-template-columns:1fr;
    gap:14px;
    margin-top:28px;
}

.portal-card{
    border:1px solid #222;
    padding:18px;
    min-height:120px;
    background:#0b0b0b;
}

.portal-card h3{
    color:#fff;
    font-size:12px;
    letter-spacing:2px;
    margin:0 0 10px 0;
    text-transform:uppercase;
}

.portal-card p{
    color:#aaa;
    margin:0 0 16px 0;
}

.tools{
    display:flex;
    gap:10px;
    margin-bottom:14px;
}

.tools input{
    width:100%;
    max-width:100%;
}

/* MATERIALS COMPACT SELECT VERSION */

.material-category{
    border-top:1px solid #222;
}

.material-category:last-child{
    border-bottom:1px solid #222;
}

.category-select-row{
    display:grid;
    grid-template-columns:1fr auto;
    gap:12px;
    align-items:end;
    padding:16px 0;
}

.category-select-row label{
    margin:0;
    line-height:1.2;
}

.category-select-row select{
    height:34px;
    margin-top:7px;
    padding:0 10px;
}

.category-select-row button,
.category-select-row .blk-add-select{
    width:auto;
    min-width:72px;
    height:34px;
    min-height:34px;
    padding:0 14px;
    align-self:end;
}

/* OLD ACCORDION FALLBACK */

.category-toggle{
    width:100%;
    display:flex;
    justify-content:space-between;
    align-items:center;
    border:none;
    border-bottom:1px solid #222;
    padding:12px 0;
    background:transparent;
    color:#fff;
    text-align:left;
    font-size:12px;
    letter-spacing:2px;
}

.category-toggle:hover{
    background:transparent;
    color:#fff;
}

.category-toggle span:last-child{
    color:#777;
    font-size:11px;
}

.material-category.open .category-toggle span:last-child{
    color:#fff;
}

.material-list{
    display:none;
    list-style:none;
    padding:0;
    margin:0;
}

.material-category.open .material-list{
    display:block;
}

.material-list li{
    display:grid;
    grid-template-columns:60px 1fr 105px auto;
    gap:10px;
    align-items:center;
    border-bottom:1px solid #181818;
    padding:10px 0;
}

.tag{color:#777}

.item{
    color:#fff;
    letter-spacing:1px;
    font-weight:500;
}

.status{
    font-size:11px;
    letter-spacing:1px;
}

.status.available{color:#f2f2f2}

.blk-add-request{
    height:34px;
    min-height:34px;
    padding:0 14px;
    font-size:10px;
}

.selected-panel{
    border-top:1px solid #222;
    border-bottom:1px solid #222;
    margin-top:32px;
    padding:16px 0;
}

.selected-head{
    display:flex;
    justify-content:space-between;
    gap:20px;
    align-items:center;
    margin-bottom:10px;
}

.selected-head strong{
    font-size:11px;
    letter-spacing:3px;
    text-transform:uppercase;
    color:#777;
    font-weight:400;
}

.selected-count{
    font-size:11px;
    color:#999;
    letter-spacing:1px;
    text-transform:uppercase;
}

#selectedMaterials{
    min-height:70px;
    border:1px solid #252525;
    background:#050505;
    color:#f0f0f0;
    padding:10px;
    white-space:pre-wrap;
}

.empty-selection{color:#666}

.private-note{
    margin-top:32px;
    color:#777;
    font-size:12px;
}

.error-message{
    display:none;
    color:#fff;
    background:#151515;
    border:1px solid #333;
    padding:10px;
    margin:12px 0;
}

@media(max-width:700px){
    :root{
        --site-width:100%;
    }

    body{padding:20px}

    .form-grid{
        grid-template-columns:1fr;
    }

    .tools{
        flex-direction:column;
    }

    .tools input{
        width:100%;
    }

    .category-select-row{
        grid-template-columns:1fr auto;
        gap:10px;
        padding:14px 0;
    }

    .category-select-row button,
    .category-select-row .blk-add-select{
        min-width:72px;
    }

    .material-list li{
        grid-template-columns:52px 1fr;
        gap:6px;
    }

    .material-list li .status,
    .material-list li button{
        grid-column:2;
    }

    .logo a{
        font-size:20px;
        letter-spacing:3px;
    }

    .selected-head{
        display:block;
    }

    .selected-count{
        display:block;
        margin-top:6px;
    }
}