:root {
    --ok-bg: #183b1e;
    --ok-line: #2e7a3b;
    --ok-text: #a7edb1;
    --err-bg: #3f1d1d;
    --err-line: #7f2f2f;
    --err-text: #ffb1b1;
}

.wrap {
    max-width: 860px;
    margin: 22px auto;
    padding: 0 12px;
}

.form {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 12px;
    background: #282b30;
    border-bottom: 1px solid #1b1d21;
}

input[type="file"] {
    flex: 1 1 300px;
    border: 1px solid #3d444d;
    background: #1f2329;
    color: #d6dde8;
    border-radius: 3px;
    padding: 6px;
}

button {
    border: 0;
    padding: 8px 14px;
    border-radius: 3px;
    background: linear-gradient(180deg, var(--accent), var(--accent-2));
    color: #fff;
    font-weight: 700;
    cursor: pointer;
}

button:hover {
    filter: brightness(1.05);
}

.flash-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 0 12px 12px;
}

.flash {
    margin: 0;
    font-size: 0.84rem;
    padding: 6px 8px;
    border-radius: 3px;
}

.flash.ok {
    background: var(--ok-bg);
    border: 1px solid var(--ok-line);
    color: var(--ok-text);
}

.flash.error {
    background: var(--err-bg);
    border: 1px solid var(--err-line);
    color: var(--err-text);
}

@media (max-width: 640px) {
    button {
        width: 100%;
    }
}

.cat-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    width: 100%;
}

.cat-select {
    flex: 1 1 160px;
    padding: 6px 8px;
    background: #1f2329;
    color: #d6dde8;
    border: 1px solid #3d444d;
    border-radius: 3px;
    font-size: 0.9rem;
}

.cat-select:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.title-row {
    width: 100%;
}

.title-input {
    width: 100%;
    box-sizing: border-box;
    padding: 7px 10px;
    background: #1f2329;
    color: #d6dde8;
    border: 1px solid #3d444d;
    border-radius: 3px;
    font-size: 0.9rem;
}

.title-input:focus {
    outline: none;
    border-color: #4a7ab5;
}
