.request-page { min-height: 100vh; }
.request-header { padding: 1.4rem 0; border-bottom: 1px solid var(--line); }
.request-header .container, .request-header-actions { display: flex; align-items: center; justify-content: space-between; }
.request-header-actions { gap: 1.5rem; }
.back-link { color: #aeb5c0; font-size: .82rem; transition: color .2s; }
.back-link i { margin-right: .55rem; color: var(--accent); }
.back-link:hover { color: white; }
.request-main { position: relative; padding: 90px 0 130px; }
.request-main > .container { max-width: 920px; }
.request-intro { max-width: 760px; margin-bottom: 5rem; }
.request-intro h1 { font-size: clamp(3rem, 7vw, 5.5rem); }
.request-intro p { max-width: 650px; margin: 1.7rem 0 0; font-size: 1.05rem; }
.request-form { display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); }
.form-section { display: grid; grid-template-columns: 90px 1fr; background: var(--surface); }
.form-section-number { padding: 2.3rem; color: var(--accent); border-right: 1px solid var(--line); font: .75rem monospace; }
.form-section-content { padding: 2.5rem 3rem 3rem; }
.form-section-content h2 { margin-bottom: 2.3rem; font-size: 1.55rem; letter-spacing: -.025em; }
.form-section-content > p { margin-top: -1.4rem; margin-bottom: 2rem; font-size: .88rem; }
.field { margin-bottom: 1.5rem; }
.field:last-child { margin-bottom: 0; }
.field label { display: block; margin-bottom: .65rem; color: #d3d7dd; font-size: .78rem; font-weight: 650; }
.field label span { margin-left: .35rem; color: #626a77; font-weight: 400; }
.field input, .field textarea, .image-description {
    width: 100%; padding: .9rem 1rem; color: var(--text); background: #0b0e13;
    border: 1px solid #292f39; border-radius: 3px; outline: none; transition: border-color .2s, box-shadow .2s;
}
.field textarea { resize: vertical; min-height: 160px; }
.field input:focus, .field textarea:focus, .image-description:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(156,255,87,.08); }
.field input::placeholder, .field textarea::placeholder, .image-description::placeholder { color: #555d68; }
.upload-zone {
    min-height: 180px; display: flex; flex-direction: column; justify-content: center; align-items: center;
    gap: .6rem; border: 1px dashed #414956; background: #0c0f14; cursor: pointer; transition: .25s;
}
.upload-zone:hover { border-color: var(--accent); background: rgba(156,255,87,.025); }
.upload-zone i { color: var(--accent); font-size: 1.8rem; margin-bottom: .35rem; }
.upload-zone strong { font-size: .9rem; }
.upload-zone small { color: #6f7784; font-size: .72rem; }
.image-list { display: grid; gap: .8rem; margin-top: 1rem; }
.image-item { display: grid; grid-template-columns: 68px 1fr auto; align-items: center; gap: 1rem; padding: .8rem; border: 1px solid var(--line); background: #0c0f14; }
.image-thumb { width: 68px; height: 58px; object-fit: cover; border-radius: 2px; }
.image-meta { min-width: 0; }
.image-name { overflow: hidden; color: #cdd2d9; font-size: .76rem; text-overflow: ellipsis; white-space: nowrap; margin-bottom: .45rem; }
.image-description { padding: .5rem .65rem; font-size: .74rem; }
.remove-image { padding: .7rem; color: #757d89; background: transparent; border: 0; }
.remove-image:hover { color: #ff7474; }
.privacy-check { display: flex; align-items: flex-start; gap: .8rem; padding: 2rem 3rem 1rem; background: var(--surface); color: #858e9c; font-size: .76rem; cursor: pointer; }
.privacy-check input { position: absolute; opacity: 0; }
.privacy-check > span { flex: 0 0 auto; width: 19px; height: 19px; display: grid; place-items: center; border: 1px solid #3c4450; }
.privacy-check > span i { display: none; color: #0b0e12; font-size: .65rem; }
.privacy-check input:checked + span { background: var(--accent); border-color: var(--accent); }
.privacy-check input:checked + span i { display: block; }
.submit-button { margin: 1rem 3rem 3rem; justify-self: start; }
.submit-button:disabled { opacity: .6; pointer-events: none; }
.form-message { display: none; margin: 2rem 3rem 0; padding: 1rem; color: #ff9b9b; background: rgba(255,80,80,.07); border: 1px solid rgba(255,80,80,.2); font-size: .82rem; }
.form-message.visible { display: block; }
.form-message.status { color: #c8fbaa; background: rgba(156,255,87,.05); border-color: rgba(156,255,87,.2); }
.request-success { padding: 6rem 2rem; text-align: center; border: 1px solid var(--line); background: var(--surface); }
.success-icon { width: 64px; height: 64px; display: grid; place-items: center; margin: 0 auto 2rem; color: #0b0e12; background: var(--accent); border-radius: 50%; }
.request-success h2 { font-size: clamp(2rem, 5vw, 3.4rem); }
.request-success p { max-width: 570px; margin: 1.5rem auto 2rem; }

@media (max-width: 767.98px) {
    .request-header-actions .language-switch { display: none; }
    .request-main { padding-top: 65px; }
    .request-intro { margin-bottom: 3rem; }
    .form-section { grid-template-columns: 1fr; }
    .form-section-number { padding: 1.5rem 1.5rem 0; border-right: 0; }
    .form-section-content { padding: 1.5rem; }
    .privacy-check { padding: 1.5rem; }
    .submit-button { margin: .5rem 1.5rem 2rem; }
    .form-message { margin-inline: 1.5rem; }
}

@media (max-width: 480px) {
    .back-link { font-size: 0; }
    .back-link i { font-size: 1rem; margin: 0; }
    .image-item { grid-template-columns: 50px 1fr auto; gap: .7rem; }
    .image-thumb { width: 50px; height: 52px; }
}
