inou/portal/static/controls.css

29 lines
2.3 KiB
CSS

/* controls.css — form elements shared across app and public pages */
.form-group { margin-bottom: 16px; }
.form-group label { font-size: 1rem; font-weight: 500; color: var(--text); margin-bottom: 4px; }
.form-group input,
.form-group select { width: 100%; padding: 10px 12px; font-size: 1rem; font-family: inherit; border: 1px solid var(--border); border-radius: 6px; background: var(--bg-card); color: var(--text); }
.form-group select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2378716C' d='M6 8L1 3h10z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; padding-right: 36px; cursor: pointer; }
.form-group input:focus,
.form-group select:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-light); }
.form-group input.code-input { font-size: 1.375rem; text-align: center; letter-spacing: 0.4em; font-weight: 500; font-family: "SF Mono", Monaco, monospace; }
.radio-group { display: flex; gap: 16px; }
.radio-group label { display: flex; align-items: center; gap: 6px; font-size: 1rem; color: var(--text); cursor: pointer; font-weight: 400; }
.radio-group input { width: auto; accent-color: var(--accent); }
.radio-pill { display: inline-block; padding: 6px 14px; border: 1px solid var(--border); border-radius: 20px; cursor: pointer; margin-right: 4px; font-size: 1rem; background: var(--bg-card); }
.radio-pill:hover { border-color: var(--accent); }
.radio-pill input { display: none; }
.radio-pill:has(input:checked) { border-color: var(--accent); background: var(--accent-light); color: var(--accent); font-weight: 500; }
.checkbox-group label { display: flex; align-items: center; gap: 8px; font-size: 1rem; color: var(--text-muted); cursor: pointer; }
.checkbox-group input { width: auto; accent-color: var(--accent); }
.checkbox-label { display: flex; align-items: flex-start; gap: 12px; cursor: pointer; }
.checkbox-label input[type="checkbox"] { width: 20px; height: 20px; margin: 0; accent-color: var(--accent); cursor: pointer; flex-shrink: 0; }
.checkbox-label span { font-size: 0.9rem; color: var(--text-muted); line-height: 1.4; }
.field-error { color: var(--danger); font-size: 0.85rem; margin-top: 4px; }