@postnord/web-components
Version:
PostNord Web Components
211 lines (210 loc) • 6.67 kB
CSS
/* Global utility variables */
/* Input styles */
/* Transition variables */
pn-input {
display: inline-flex;
flex-direction: column;
}
pn-input .pn-input {
--pn-input-offset-left: 0em;
--pn-input-offset-right: 0em;
}
pn-input .pn-input-label {
cursor: pointer;
display: flex;
justify-content: space-between;
align-items: flex-end;
font-weight: 400;
color: #2d2013;
margin: 0 0 0.25em 0;
gap: 0.5em;
-webkit-tap-highlight-color: transparent;
transition-property: color, transform;
transition-duration: 0.2s;
transition-timing-function: cubic-bezier(0.7, 0, 0.3, 1);
}
@media (prefers-reduced-motion: reduce) {
pn-input .pn-input-label {
transition-duration: 0s;
transition-delay: 0s;
}
}
pn-input .pn-input-label[data-compact] {
position: absolute;
top: 1.5625em;
left: calc(var(--pn-input-offset-left, 0px) + 0.75em + 0.0625em);
margin: 0;
pointer-events: none;
align-items: center;
height: 1.5em;
max-width: calc(100% - (var(--pn-input-offset-left, 0px) + 0.75em) - (var(--pn-input-offset-right, 0px) + 0.75em));
transform: translateY(-50%) scale(1) translateZ(0);
transform-origin: 0 0;
transition-delay: 0.2s;
}
pn-input .pn-input-label[data-compact] > span {
font-size: 1em;
text-overflow: ellipsis;
overflow: hidden;
white-space: nowrap;
line-height: 1.5em;
}
pn-input .pn-input-label > span {
font-size: 0.875em;
}
pn-input .pn-input-group {
position: relative;
}
pn-input .pn-input-element {
width: 100%;
color: #2d2013;
background-color: #ffffff;
border: 0.0625em solid #969087;
border-radius: 0.5em;
padding: 0.75em calc(0.75em + var(--pn-input-offset-right)) 0.75em calc(0.75em + var(--pn-input-offset-left));
font-family: inherit;
font-size: 1em;
font-weight: 500;
line-height: 1.5em;
-webkit-font-smoothing: antialiased;
-webkit-tap-highlight-color: transparent;
}
pn-input .pn-input-element:-webkit-autofill, pn-input .pn-input-element:-webkit-autofill:hover, pn-input .pn-input-element:-webkit-autofill:focus, pn-input .pn-input-element:-webkit-autofill:active {
-webkit-box-shadow: 0 0 0 10em #e0f8ff inset;
-webkit-text-fill-color: #2d2013;
}
pn-input .pn-input-element {
outline: 0.2rem solid transparent;
outline-offset: 0.2rem;
}
pn-input .pn-input-element:focus-visible {
outline-color: #005d92;
background-color: #ffffff;
border-color: #005d92;
}
pn-input .pn-input-element {
transition-property: outline-color, background-color, border-color, color;
transition-duration: 0.2s;
transition-timing-function: cubic-bezier(0.7, 0, 0.3, 1);
}
@media (prefers-reduced-motion: reduce) {
pn-input .pn-input-element {
transition-duration: 0s;
transition-delay: 0s;
}
}
pn-input .pn-input-element[data-compact] {
text-align: left;
padding-top: 1.125em;
padding-bottom: 0.375em;
max-width: unset;
}
pn-input .pn-input-element[data-compact]::placeholder {
color: transparent;
}
pn-input .pn-input-element[data-compact]:focus + .pn-input-label, pn-input .pn-input-element[data-compact]:not(:placeholder-shown) + .pn-input-label {
transform: translateY(-85%) scale(0.75);
transition-delay: 0s;
}
pn-input .pn-input-element::placeholder {
color: #5e554a;
font-weight: normal;
}
pn-input .pn-input-element:hover {
border-color: #005d92;
}
pn-input .pn-input-element:disabled {
color: #5e554a;
background-color: #f3f2f2;
border-color: #f3f2f2;
}
pn-input .pn-input-element:read-only {
border-color: #ffffff;
}
pn-input .pn-input-element:disabled ~ .pn-input-eyecandy > pn-icon > .pn-icon-svg > path {
fill: #969087;
}
pn-input .pn-input-element::-webkit-calendar-picker-indicator {
visibility: hidden;
display: none ;
}
pn-input .pn-input-element::-webkit-textfield-decoration-container, pn-input .pn-input-element::-webkit-search-cancel-button, pn-input .pn-input-element::-webkit-inner-spin-button, pn-input .pn-input-element::-webkit-outer-spin-button, pn-input .pn-input-element::-webkit-search-decoration {
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
}
pn-input .pn-input-element[type=number] {
appearance: textfield;
}
pn-input .pn-input-eyecandy {
position: absolute;
top: 50%;
transform: translateY(-50%);
display: inline-flex;
align-items: center;
gap: 0.5em;
height: 1.5em;
}
pn-input .pn-input-eyecandy[data-prefix] {
left: 0.75em;
}
pn-input .pn-input-eyecandy[data-suffix] {
right: 0.75em;
}
pn-input .pn-input-text {
color: #5e554a;
font-weight: 400;
line-height: 1.5em;
}
pn-input .pn-input-message {
color: #5e554a;
font-size: 0.875em;
font-weight: 400;
margin: 0.25em 0 0 0;
display: flex;
flex-direction: column;
gap: 0.25em;
}
pn-input .pn-input-message[hidden],
pn-input .pn-input-message > span[hidden] {
display: none;
}
pn-input .pn-input[data-error] > .pn-input-label {
color: #a70707;
}
pn-input .pn-input[data-error] > .pn-input-group > .pn-input-element {
border-color: #a70707;
}
pn-input .pn-input[data-error] > .pn-input-group > .pn-input-element:hover {
border-color: #500715;
}
pn-input .pn-input[data-error] > .pn-input-group > .pn-input-element:focus-visible {
background-color: #ffffff;
border-color: #a70707;
outline-color: #a70707;
}
pn-input .pn-input[data-error] > .pn-input-group > .pn-input-element:-webkit-autofill, pn-input .pn-input[data-error] > .pn-input-group > .pn-input-element:-webkit-autofill:hover, pn-input .pn-input[data-error] > .pn-input-group > .pn-input-element:-webkit-autofill:focus, pn-input .pn-input[data-error] > .pn-input-group > .pn-input-element:-webkit-autofill:active {
-webkit-box-shadow: 0 0 0 10em #fef7f6 inset;
-webkit-text-fill-color: #2d2013;
}
pn-input .pn-input[data-error] > .pn-input-message[role=alert] {
color: #a70707;
}
pn-input .pn-input[data-valid] > .pn-input-label {
color: #005e41;
}
pn-input .pn-input[data-valid] > .pn-input-group > .pn-input-element {
border-color: #005e41;
}
pn-input .pn-input[data-valid] > .pn-input-group > .pn-input-element:hover {
border-color: #002f24;
}
pn-input .pn-input[data-valid] > .pn-input-group > .pn-input-element:focus-visible {
background-color: #ffffff;
border-color: #005e41;
outline-color: #005e41;
}
pn-input .pn-input[data-valid] > .pn-input-group > .pn-input-element:-webkit-autofill, pn-input .pn-input[data-valid] > .pn-input-group > .pn-input-element:-webkit-autofill:hover, pn-input .pn-input[data-valid] > .pn-input-group > .pn-input-element:-webkit-autofill:focus, pn-input .pn-input[data-valid] > .pn-input-group > .pn-input-element:-webkit-autofill:active {
-webkit-box-shadow: 0 0 0 10em #edfbf3 inset;
-webkit-text-fill-color: #2d2013;
}