/* GENERAL STYLES FOR FORMS */ /* FORMS */ input[type="text"], input[type="password"], input[type="url"], input[type="number"], input[type="email"] { background-color: rgba(0, 0, 0, 0.05); padding: 7px 3px 7px; outline: 0; border: 0; border-bottom: 2px solid var(--darkbase); box-shadow: 0 2px 13px rgba(0, 0, 0, 0.05); color: var(--fontbase); transition: all .1s; font-size: 16px; min-width: 300px; } input[type="text"]:focus, input[type="password"]:focus, input[type="url"]:focus, input[type="number"]:focus, input[type="email"]:focus { border-bottom-color: var(--lightbase); background-color: transparent; } input[type="submit"], input[type="button"], button { outline: 0; border: 0; box-shadow: 0; background-color: var(--lightbase); color: white; padding: 10px 17px; min-width: 100px; transition: all .1s; font-size: 16px; cursor: pointer; border-radius: 4px; } input[type="submit"][disabled], input[type="button"][disabled], button[disabled] { opacity: 0.3; background-color: var(--greybase); cursor: default; } input[type="submit"]:not([disabled]):hover, input[type="button"]:not([disabled]):hover, button:not([disabled]):hover { background-color: var(--lighterbase); } textarea { outline: 0; border: 0; padding: 7px 4px; min-width: 300px; min-height: 100px; font-family: var(--fontfamilybase); font-size: 16px; color: var(--fontbase); background-color: rgba(0, 0, 0, 0.05); box-shadow: 0 2px 13px rgba(0, 0, 0, 0.05); border-bottom: 2px solid var(--darkbase); } textarea:focus { background-color: transparent; border-bottom-color: var(--lightbase); } .form-group { position: relative; display: grid; grid-template-columns: repeat(3, minmax(150px, max-content)); grid-auto-rows: 30px; grid-gap: 10px; align-items: center; margin: 10px 0; margin-left: -20px; padding-left: 10px; border-left: 8px solid transparent; } .form-group--required { border-left: 8px solid var(--lighterbase); } .form-group--valid { border-left: 8px solid #2dcc35; } .form-group--has-error { border-left: 8px solid var(--errorbase) !important; } .form-group__add-entry, .form-group__remove-entry { display: block; width: 40px; height: 30px; background-color: var(--lightbase); border-radius: 2px; position: relative; grid-column-start: 3; } .form-group__remove-entry { background-color: var(--warningbase); } .form-group__remove-entry::after { content: none; } .form-group__add-entry::before, .form-group__add-entry::after, .form-group__remove-entry::after { content: ''; position: absolute; } .form-group__add-entry::before { width: 4px; height: 20px; background-color: white; transform: translate(18px, 5px); } .form-group__add-entry::after, .form-group__remove-entry::after { width: 20px; height: 4px; background-color: white; transform: translate(10px, 13px); } /* CUSTOM LEGACY CHECKBOX AND RADIO BOXES */ input[type="checkbox"] { position: relative; height: 20px; width: 20px; -webkit-appearance: none; cursor: pointer; } input[type="checkbox"]::before { content: ''; position: absolute; width: 20px; height: 20px; background-color: var(--lighterbase); display: flex; align-items: center; justify-content: center; border-radius: 2px; } input[type="checkbox"]:checked::before { background-color: var(--lightbase); } input[type="checkbox"]:checked::after { content: '✓'; position: absolute; width: 20px; height: 20px; display: flex; align-items: center; justify-content: center; color: white; font-size: 20px; } /* CUSTOM CHECKBOXES AND RADIO BOXES */ /* Completely replaces legacy checkbox and radiobox */ .checkbox, .radio { position: relative; margin: 3px; > [type="checkbox"], > [type="radio"] { display: none; } > label { display: block; padding: 7px 13px 7px 30px; background-color: var(--darkbase); border-radius: 4px; color: white; cursor: pointer; } > label::before, > label::after { content: ''; position: absolute; top: 15px; left: 4px; display: block; width: 20px; height: 20px; background-color: white; transition: all .2s; } > label::before { width: 20px; height: 2px; transform: scale(0.8, 0.1); } > label::after { width: 20px; height: 2px; transform: scale(0.8, 0.1); } > :checked + label { background-color: var(--lightbase); text-decoration: underline; } &:hover > label::before, > :checked + label::before { transform: scale(1, 1) rotate(45deg); } &:hover > label::after, > :checked + label::after { transform: scale(1, 1) rotate(-45deg); } } .radio > label::before { transform: scale(0.01, 0.01) rotate(45deg); } .radio > label::after { transform: scale(0.01, 0.01) rotate(-45deg); } .radio::before { content: ''; position: absolute; top: 2px; left: 2px; right: 2px; bottom: 2px; border-radius: 4px; border: 2px solid white; z-index: -1; } /* REACTIVE LABELS */ .reactive-label { cursor: text; color: var(--fontsec); transform: translate(0, 0); transition: all .1s; } .reactive-label--small { cursor: default; color: var(--fontbase); } @media (max-width: 999px) { .form-group { grid-template-rows: 30px auto; grid-template-columns: 1fr; align-items: baseline; margin-top: 17px; } .reactive-label { position: relative; transform: translate(2px, 30px); } .reactive-label--small { transform: translate(2px, 0px); color: var(--fontsec); /*font-size: 14px;*/ } } /* CUSTOM FILE INPUT */ input[type="file"] { grid-column-start: 2; color: white; width: 0.1px; height: 0.1px; opacity: 0; overflow: hidden; position: absolute; z-index: -1; outline: 0; border: 0; } .form-group__file-input-container { border-radius: 2px; background-color: var(--darkbase); padding: 7px 13px; color: var(--whitebase); grid-column-start: 2; text-align: left; cursor: pointer; } .form-group__file-input-label { }