div.uniformInputGroup{ background: white; border: 1px solid lighten($gray, 40); display: flex; align-items: center; transition: box-shadow 0.2s ease-in; &>*{ flex: 0 1 auto; } input{ border: none !important; background:none; appearance: none; outline: none; display:block; width: 100%; border-radius: 0 !important; &:focus{ box-shadow: none; } } .input{ padding: 0; flex: 1 1 auto; } &>*:not(input){ padding: 0 0.5em; &.pad-tiny{ padding: 0 0.25em; } } &.focus{ box-shadow: inset 0 -2px 0 $green; } .label{ color: lighten($gray, 20); } @include media($sm){ input{ padding-top: 0.5em; padding-bottom: 0.5em; } } &.border-none{ border: none; } } select.uniformInput, textarea.uniformInput, input.uniformInput, button.uniformInput, .uniformInput input, .uniformForm #{$text-inputs}, .uniformForm textarea{ font-family: $system-font; border:1px solid lighten($gray, 40); padding: 0.5em; line-height: 1.3; outline: none; appearance: none; transition: box-shadow 0.2s ease-in; &:focus{ box-shadow: inset 0 -2px 0 $green; } &.block{ width: 100%; max-width: 100%; } @include media($sm){ font-size: 1.142em; } &.pad-more{ padding: 1em; } &.large{ font-size:1.2em; } } select.uniformInput{ color: $gray; background: white url(); background-position: center right; background-repeat: no-repeat; background-size: auto 40%; position: relative; border-radius: 0; padding-right: 1.5em !important; } button.uniformInput{ background: white; @include text-overflow; } .uniformError{ position:relative; border-color: $red; color: $red; input{ border-color: $red !important; } } .uniformErrorMessage{ color: $red; font-size:11px; line-height: 1.1; } @mixin uniformForm-table{ display: table; width: 100%; .form-group{ display: table-row; & > * { display: table-cell; &.fill{ width: 100%; } } & > label, & > div, & > span { padding-bottom: 1em; padding-right: 0.5em; &:last-child{ padding-right: 0; } } } } .uniformForm{ .form-group{ position: relative; margin-bottom: 0.9em; label{ font-weight:bold; display:block; } &.collapse{ margin-bottom: 0; } } [data-error-message]{ position: relative; color: $red; input{ border-color: $red !important; } &::after{ content: attr(data-error-message); color: $red; position: absolute; bottom: -7px; left: 1em; border: 1px solid $red; background: white; font-size:11px; line-height: 14px; @include text-overflow; padding: 0 0.5em; max-width: 100%; } } select.uniformInput, #{$text-inputs}, textarea{ display:block; width: 100%; max-width: 100%; } .uniformForm-table, &.uniformForm-table{ @include uniformForm-table; } &.invert{ #{$text-inputs}, textarea, .uniformCheckboxCollection.inline, .uniformCheckboxCollection.inline-md{ border-color: $gray; border-radius: 0.25em; } .has-error{ color: $red-bright; } .uniformInputGroup{ overflow: hidden; border-color: $gray; border-radius: 0.25em; } } } @include apply-media-sizes('.uniformCheckboxCollection'){ label{ display:block; margin-right: 1em; font-weight: normal; input{ margin-right: 0.25em; } } &.inline{ color: $gray; border:1px solid lighten($gray, 40); background: white; display: flex; align-items: center; label{ margin-right: 0; padding: 0.5em; line-height: 1.3; flex: 1 1 auto; border-left: 1px solid lighten($gray, 40); text-align: center; &:first-of-type{ border-left:none; } } } } @include apply-media-sizes('.uniformForm-table'){ @include uniformForm-table; } .uniformFloatingLabel{ display: flex; align-items: center; border: 1px solid lighten($gray, 40); position:relative; background:white; &>*{ flex: 0 1 auto; } label{ z-index: 1; padding: 0 1em; font-weight:normal !important; } & > input, & > textarea, & > select, & > .uniformInputGroup{ position:relative; display:block; width: 100%; border:none !important; background:none; } & > select { z-index: 2; } & > .uniformInputGroup{ display: flex; } &.enabled{ label{ transition: font-size 0.1s, line-height 0.1s, opacity 0.1s; } } &.inactive{ input, textarea, select{ &::placeholder{ color: transparent; } } } &.float{ label{ font-size: 80%; opacity: 0.8; } } &.active{ label{ color: $green-dark; opacity: 1; } } input.pad-more{ padding: 1em; } }