/* =============================================================
   AethCore — forms.css
   Buttons, form fields, form feedback, and data tables.
   ============================================================= */

/* --- Buttons --- */

.btn {
    display: inline-block;
    padding: 6px 16px;
    font-size: 12px;
    font-weight: bold;
    font-family: Tahoma, Verdana, Arial, sans-serif;
    text-transform: uppercase;
    letter-spacing: 1px;
    text-decoration: none;
    border: 1px solid #a04000;
    background: linear-gradient(180deg, #e06000 0%, #b84800 100%);
    color: #fff;
    cursor: pointer;
    box-sizing: border-box;
    line-height: 1.4;
}

.btn:hover {
    background: linear-gradient(180deg, #f07000 0%, #c85200 100%);
    text-decoration: none;
    color: #fff;
}

.btn-primary {
    display: inline-block;
    padding: 6px 16px;
    font-size: 12px;
    font-weight: bold;
    text-transform: uppercase;
    letter-spacing: 1px;
    text-decoration: none;
    border: 1px solid #a04000;
    background: linear-gradient(180deg, #e06000 0%, #b84800 100%);
    color: #fff;
}

.btn-primary:hover {
    background: linear-gradient(180deg, #f07000 0%, #c85200 100%);
    text-decoration: none;
    color: #fff;
}

.btn-small,
.btn-sm {
    padding: 3px 10px;
    font-size: 10px;
    letter-spacing: 0.5px;
}

.btn-ghost {
    display: inline-block;
    padding: 6px 16px;
    font-size: 12px;
    font-weight: bold;
    text-transform: uppercase;
    letter-spacing: 1px;
    text-decoration: none;
    border: 1px solid #b0b0b0;
    background: transparent;
    color: #555;
}

.btn-ghost:hover {
    background: #f0f0f0;
    color: #333;
    text-decoration: none;
}

.btn-secondary {
    background: linear-gradient(180deg, #666 0%, #444 100%);
    border-color: #333;
}

.btn-secondary:hover {
    background: linear-gradient(180deg, #777 0%, #555 100%);
}

/* --- Form fields --- */

.field {
    margin-bottom: 11px;
}

.field label {
    display: block;
    font-size: 11px;
    font-weight: bold;
    color: #444;
    margin-bottom: 3px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.field input[type="text"],
.field input[type="number"],
.field input[type="url"],
.field input[type="email"],
.field input[type="password"],
.field textarea {
    width: 100%;
    padding: 5px 7px;
    font-size: 12px;
    font-family: inherit;
    border: 1px solid #b0b0b0;
    background: #fff;
    color: #222;
    outline: none;
}

.field input:focus,
.field textarea:focus {
    border-color: #c85000;
}

.field textarea {
    resize: vertical;
    min-height: 80px;
}

.field-actions {
    margin-top: 14px;
    display: flex;
    gap: 8px;
    align-items: center;
}

.field-hint {
    display: block;
    font-size: 11px;
    color: #888;
    margin: 6px 0 2px;
}

.settings-form {
    max-width: 460px;
}

.settings-avatar-preview {
    display: block;
    width: 64px;
    height: 64px;
    object-fit: cover;
    border: 1px solid #b0b0b0;
    margin-bottom: 6px;
}

.settings-hint {
    font-size: 12px;
    color: #666;
    margin-bottom: 10px;
}

.game-cover-preview {
    display: block;
    width: 60px;
    height: 80px;
    object-fit: cover;
    border: 1px solid #b0b0b0;
    margin-bottom: 6px;
}

/* --- Form feedback --- */

.form-success {
    background: #e8f5e0;
    border: 1px solid #8bc34a;
    color: #3a6000;
    padding: 7px 10px;
    font-size: 12px;
    margin-bottom: 12px;
}

.form-error {
    background: #fdecea;
    border: 1px solid #e57373;
    color: #7a1010;
    padding: 7px 10px;
    font-size: 12px;
    margin-bottom: 12px;
}

.form-errors {
    background: #fdecea;
    border: 1px solid #e57373;
    color: #7a1010;
    padding: 7px 10px 7px 24px;
    font-size: 12px;
    margin-bottom: 12px;
}

.form-errors li {
    margin-bottom: 2px;
}

.form-errors li:last-child {
    margin-bottom: 0;
}

.form-group {
    margin-bottom: 11px;
}

.form-group label {
    display: block;
    font-size: 11px;
    font-weight: bold;
    color: #444;
    margin-bottom: 3px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.form-group input[type="text"],
.form-group input[type="number"],
.form-group input[type="url"],
.form-group input[type="email"],
.form-group input[type="password"],
.form-group textarea,
.form-group select {
    width: 100%;
    padding: 5px 7px;
    font-size: 12px;
    font-family: inherit;
    border: 1px solid #b0b0b0;
    background: #fff;
    color: #222;
    outline: none;
}

.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
    border-color: #c85000;
}

.form-group textarea {
    resize: vertical;
    min-height: 80px;
}

.field-group-label {
    font-size: 12px;
    font-weight: bold;
    color: #444;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin: 14px 0 6px;
}

.form-alt {
    margin-top: 12px;
    font-size: 11px;
    color: #666;
}

/* Alert banner (pending requests notice above module) */
.alert-banner {
    background: #fff8e1;
    border: 1px solid #ffc107;
    border-bottom: none;
    padding: 6px 12px;
    font-size: 12px;
    color: #5a4000;
}

.alert-banner a {
    color: #5a4000;
    font-weight: bold;
    text-decoration: underline;
}

/* --- Data table (game requests list) --- */

.data-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 12px;
}

.data-table th {
    text-align: left;
    padding: 5px 8px;
    border-bottom: 2px solid #d0d0d0;
    color: #555;
    font-weight: bold;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.data-table td {
    padding: 6px 8px;
    border-bottom: 1px solid #eee;
    vertical-align: middle;
}

.data-table tr:last-child td {
    border-bottom: none;
}

/* --- Game picker autocomplete --- */

.game-picker {
    position: relative;
}

.game-picker-wrap {
    display: flex;
    align-items: stretch;
}

.game-picker-wrap .game-picker-input {
    flex: 1;
    padding: 5px 7px;
    font-size: 12px;
    font-family: inherit;
    border: 1px solid #b0b0b0;
    background: #fff;
    color: #222;
    outline: none;
    min-width: 0;
}

.game-picker-wrap .game-picker-input:focus {
    border-color: #c85000;
}

.game-picker-clear {
    padding: 0 8px;
    border: 1px solid #b0b0b0;
    border-left: none;
    background: #f0f0f0;
    color: #888;
    font-size: 16px;
    line-height: 1;
    cursor: pointer;
}

.game-picker-clear:hover {
    background: #e0e0e0;
    color: #333;
}

.game-picker-results {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: #fff;
    border: 1px solid #b0b0b0;
    border-top: none;
    z-index: 100;
    max-height: 180px;
    overflow-y: auto;
}

.game-picker-item {
    padding: 5px 8px;
    font-size: 12px;
    cursor: pointer;
    color: #222;
}

.game-picker-item:hover {
    background: #f0e8d8;
    color: #b84800;
}
