Created
January 25, 2025 22:35
-
-
Save j2deme/4aee2730f23991ff4cdee2c35e3862a9 to your computer and use it in GitHub Desktop.
no-side-effects-pico
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
:root { | |
--pico-font-family-emoji: "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; | |
--pico-font-family-sans-serif: system-ui, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, Helvetica, Arial, "Helvetica Neue", sans-serif, var(--pico-font-family-emoji); | |
--pico-font-family-monospace: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace, var(--pico-font-family-emoji); | |
--pico-font-family: var(--pico-font-family-sans-serif); | |
--pico-line-height: 1.5; | |
--pico-font-weight: 400; | |
--pico-font-size: 100%; | |
--pico-text-underline-offset: 0.1rem; | |
--pico-border-radius: 0.25rem; | |
--pico-border-width: 0.0625rem; | |
--pico-outline-width: 0.125rem; | |
--pico-transition: 0.2s ease-in-out; | |
--pico-spacing: 1rem; | |
--pico-typography-spacing-vertical: 1rem; | |
--pico-block-spacing-vertical: var(--pico-spacing); | |
--pico-block-spacing-horizontal: var(--pico-spacing); | |
--pico-grid-column-gap: var(--pico-spacing); | |
--pico-grid-row-gap: var(--pico-spacing); | |
--pico-form-element-spacing-vertical: 0.75rem; | |
--pico-form-element-spacing-horizontal: 1rem; | |
--pico-group-box-shadow: 0 0 0 rgba(0, 0, 0, 0); | |
--pico-group-box-shadow-focus-with-button: 0 0 0 var(--pico-outline-width) var(--pico-primary-focus); | |
--pico-group-box-shadow-focus-with-input: 0 0 0 0.0625rem var(--pico-form-element-border-color); | |
--pico-modal-overlay-backdrop-filter: blur(0.375rem); | |
--pico-nav-element-spacing-vertical: 1rem; | |
--pico-nav-element-spacing-horizontal: 0.5rem; | |
--pico-nav-link-spacing-vertical: 0.5rem; | |
--pico-nav-link-spacing-horizontal: 0.5rem; | |
--pico-nav-breadcrumb-divider: ">"; | |
--pico-icon-checkbox: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgb(255, 255, 255)' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E"); | |
--pico-icon-minus: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgb(255, 255, 255)' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='5' y1='12' x2='19' y2='12'%3E%3C/line%3E%3C/svg%3E"); | |
--pico-icon-chevron: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgb(136, 145, 164)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E"); | |
--pico-icon-date: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgb(136, 145, 164)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E"); | |
--pico-icon-time: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgb(136, 145, 164)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cpolyline points='12 6 12 12 16 14'%3E%3C/polyline%3E%3C/svg%3E"); | |
--pico-icon-search: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgb(136, 145, 164)' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'%3E%3C/line%3E%3C/svg%3E"); | |
--pico-icon-close: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgb(136, 145, 164)' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'%3E%3C/line%3E%3Cline x1='6' y1='6' x2='18' y2='18'%3E%3C/line%3E%3C/svg%3E"); | |
--pico-icon-loading: url("data:image/svg+xml,%3Csvg fill='none' height='24' width='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg' %3E%3Cstyle%3E g %7B animation: rotate 2s linear infinite; transform-origin: center center; %7D circle %7B stroke-dasharray: 75,100; stroke-dashoffset: -5; animation: dash 1.5s ease-in-out infinite; stroke-linecap: round; %7D @keyframes rotate %7B 0%25 %7B transform: rotate(0deg); %7D 100%25 %7B transform: rotate(360deg); %7D %7D @keyframes dash %7B 0%25 %7B stroke-dasharray: 1,100; stroke-dashoffset: 0; %7D 50%25 %7B stroke-dasharray: 44.5,100; stroke-dashoffset: -17.5; %7D 100%25 %7B stroke-dasharray: 44.5,100; stroke-dashoffset: -62; %7D %7D %3C/style%3E%3Cg%3E%3Ccircle cx='12' cy='12' r='10' fill='none' stroke='rgb(136, 145, 164)' stroke-width='4' /%3E%3C/g%3E%3C/svg%3E"); | |
} | |
/** | |
* Section | |
*/ | |
.pico section { | |
margin-bottom: var(--pico-block-spacing-vertical); | |
} | |
/** | |
* Container | |
*/ | |
.pico.container, | |
.pico.container-fluid { | |
width: 100%; | |
margin-right: auto; | |
margin-left: auto; | |
padding-right: var(--pico-spacing); | |
padding-left: var(--pico-spacing); | |
} | |
@media (min-width: 576px) { | |
.pico.container { | |
max-width: 510px; | |
padding-right: 0; | |
padding-left: 0; | |
} | |
} | |
@media (min-width: 768px) { | |
.pico.container { | |
max-width: 700px; | |
} | |
} | |
@media (min-width: 1024px) { | |
.pico.container { | |
max-width: 950px; | |
} | |
} | |
@media (min-width: 1280px) { | |
.pico.container { | |
max-width: 1200px; | |
} | |
} | |
@media (min-width: 1536px) { | |
.pico.container { | |
max-width: 1450px; | |
} | |
} | |
/** | |
* Grid | |
* Minimal grid system with auto-layout columns | |
*/ | |
.pico.grid { | |
grid-column-gap: var(--pico-grid-column-gap); | |
grid-row-gap: var(--pico-grid-row-gap); | |
display: grid; | |
grid-template-columns: 1fr; | |
} | |
@media (min-width: 768px) { | |
.pico.grid { | |
grid-template-columns: repeat(auto-fit, minmax(0%, 1fr)); | |
} | |
} | |
.pico.grid>* { | |
min-width: 0; | |
} | |
/** | |
* Overflow auto | |
*/ | |
.pico .overflow-auto { | |
overflow: auto; | |
} | |
a { | |
--pico-text-decoration: underline; | |
} | |
a.secondary, | |
a.contrast { | |
--pico-text-decoration: underline; | |
} | |
small { | |
--pico-font-size: 0.875em; | |
} | |
.pico h1, | |
.pico h2, | |
.pico h3, | |
.pico h4, | |
.pico h5, | |
.pico h6 { | |
--pico-font-weight: 700; | |
} | |
.pico h1 { | |
--pico-font-size: 2rem; | |
--pico-line-height: 1.125; | |
--pico-typography-spacing-top: 3rem; | |
} | |
.pico h2 { | |
--pico-font-size: 1.75rem; | |
--pico-line-height: 1.15; | |
--pico-typography-spacing-top: 2.625rem; | |
} | |
.pico h3 { | |
--pico-font-size: 1.5rem; | |
--pico-line-height: 1.175; | |
--pico-typography-spacing-top: 2.25rem; | |
} | |
.pico h4 { | |
--pico-font-size: 1.25rem; | |
--pico-line-height: 1.2; | |
--pico-typography-spacing-top: 1.874rem; | |
} | |
.pico h5 { | |
--pico-font-size: 1.125rem; | |
--pico-line-height: 1.225; | |
--pico-typography-spacing-top: 1.6875rem; | |
} | |
.pico h6 { | |
--pico-font-size: 1rem; | |
--pico-line-height: 1.25; | |
--pico-typography-spacing-top: 1.5rem; | |
} | |
.pico thead th, | |
.pico thead td, | |
.pico tfoot th, | |
.pico tfoot td { | |
--pico-font-weight: 600; | |
--pico-border-width: 0.1875rem; | |
} | |
.pico pre, | |
.pico code, | |
.pico kbd, | |
.pico samp { | |
--pico-font-family: var(--pico-font-family-monospace); | |
} | |
.pico kbd { | |
--pico-font-weight: bolder; | |
} | |
/** | |
* Typography | |
*/ | |
.pico b, | |
.pico strong { | |
font-weight: bolder; | |
} | |
.pico sub, | |
.pico sup { | |
position: relative; | |
font-size: 0.75em; | |
line-height: 0; | |
vertical-align: baseline; | |
} | |
.pico sub { | |
bottom: -0.25em; | |
} | |
.pico sup { | |
top: -0.5em; | |
} | |
.pico address, | |
.pico blockquote, | |
.pico dl, | |
.pico ol, | |
.pico p, | |
.pico pre, | |
.pico table, | |
.pico ul { | |
margin-top: 0; | |
margin-bottom: var(--pico-typography-spacing-vertical); | |
color: var(--pico-color); | |
font-style: normal; | |
font-weight: var(--pico-font-weight); | |
} | |
.pico h1, | |
.pico h2, | |
.pico h3, | |
.pico h4, | |
.pico h5, | |
.pico h6 { | |
margin-top: 0; | |
margin-bottom: var(--pico-typography-spacing-vertical); | |
color: var(--pico-color); | |
font-weight: var(--pico-font-weight); | |
font-size: var(--pico-font-size); | |
line-height: var(--pico-line-height); | |
font-family: var(--pico-font-family); | |
} | |
.pico h1 { | |
--pico-color: var(--pico-h1-color); | |
} | |
.pico h2 { | |
--pico-color: var(--pico-h2-color); | |
} | |
.pico h3 { | |
--pico-color: var(--pico-h3-color); | |
} | |
.pico h4 { | |
--pico-color: var(--pico-h4-color); | |
} | |
.pico h5 { | |
--pico-color: var(--pico-h5-color); | |
} | |
.pico h6 { | |
--pico-color: var(--pico-h6-color); | |
} | |
.pico :where(article, address, blockquote, dl, figure, form, ol, p, pre, table, ul)~ :is(h1, h2, h3, h4, h5, h6) { | |
margin-top: var(--pico-typography-spacing-top); | |
} | |
.pico p { | |
margin-bottom: var(--pico-typography-spacing-vertical); | |
} | |
.pico hgroup { | |
margin-bottom: var(--pico-typography-spacing-vertical); | |
} | |
.pico hgroup>* { | |
margin-top: 0; | |
margin-bottom: 0; | |
} | |
.pico hgroup>*:not(:first-child):last-child { | |
--pico-color: var(--pico-muted-color); | |
--pico-font-weight: unset; | |
font-size: 1rem; | |
} | |
.pico :where(ol, ul) li { | |
margin-bottom: calc(var(--pico-typography-spacing-vertical) * 0.25); | |
} | |
.pico :where(dl, ol, ul) :where(dl, ol, ul) { | |
margin: 0; | |
margin-top: calc(var(--pico-typography-spacing-vertical) * 0.25); | |
} | |
.pico ul li { | |
list-style: square; | |
} | |
.pico mark { | |
padding: 0.125rem 0.25rem; | |
background-color: var(--pico-mark-background-color); | |
color: var(--pico-mark-color); | |
vertical-align: baseline; | |
} | |
.pico blockquote { | |
display: block; | |
margin: var(--pico-typography-spacing-vertical) 0; | |
padding: var(--pico-spacing); | |
border-right: none; | |
border-left: 0.25rem solid var(--pico-blockquote-border-color); | |
border-inline-start: 0.25rem solid var(--pico-blockquote-border-color); | |
border-inline-end: none; | |
} | |
.pico blockquote footer { | |
margin-top: calc(var(--pico-typography-spacing-vertical) * 0.5); | |
color: var(--pico-blockquote-footer-color); | |
} | |
.pico abbr[title] { | |
border-bottom: 1px dotted; | |
text-decoration: none; | |
cursor: help; | |
} | |
.pico ins { | |
color: var(--pico-ins-color); | |
text-decoration: none; | |
} | |
.pico del { | |
color: var(--pico-del-color); | |
} | |
.pico ::-moz-selection { | |
background-color: var(--pico-text-selection-color); | |
} | |
.pico ::selection { | |
background-color: var(--pico-text-selection-color); | |
} | |
/** | |
* Link | |
*/ | |
.pico :where(a:not([role=button])), | |
.pico [role=link] { | |
--pico-color: var(--pico-primary); | |
--pico-background-color: transparent; | |
--pico-underline: var(--pico-primary-underline); | |
outline: none; | |
background-color: var(--pico-background-color); | |
color: var(--pico-color); | |
-webkit-text-decoration: var(--pico-text-decoration); | |
text-decoration: var(--pico-text-decoration); | |
text-decoration-color: var(--pico-underline); | |
text-underline-offset: 0.125em; | |
transition: background-color var(--pico-transition), color var(--pico-transition), box-shadow var(--pico-transition), -webkit-text-decoration var(--pico-transition); | |
transition: background-color var(--pico-transition), color var(--pico-transition), text-decoration var(--pico-transition), box-shadow var(--pico-transition); | |
transition: background-color var(--pico-transition), color var(--pico-transition), text-decoration var(--pico-transition), box-shadow var(--pico-transition), -webkit-text-decoration var(--pico-transition); | |
} | |
.pico :where(a:not([role=button])):is([aria-current]:not([aria-current=false]), :hover, :active, :focus), | |
.pico [role=link]:is([aria-current]:not([aria-current=false]), :hover, :active, :focus) { | |
--pico-color: var(--pico-primary-hover); | |
--pico-underline: var(--pico-primary-hover-underline); | |
--pico-text-decoration: underline; | |
} | |
.pico :where(a:not([role=button])):focus-visible, | |
.pico [role=link]:focus-visible { | |
box-shadow: 0 0 0 var(--pico-outline-width) var(--pico-primary-focus); | |
} | |
.pico :where(a:not([role=button])).secondary, | |
.pico [role=link].secondary { | |
--pico-color: var(--pico-secondary); | |
--pico-underline: var(--pico-secondary-underline); | |
} | |
.pico :where(a:not([role=button])).secondary:is([aria-current]:not([aria-current=false]), :hover, :active, :focus), | |
.pico [role=link].secondary:is([aria-current]:not([aria-current=false]), :hover, :active, :focus) { | |
--pico-color: var(--pico-secondary-hover); | |
--pico-underline: var(--pico-secondary-hover-underline); | |
} | |
.pico :where(a:not([role=button])).contrast, | |
.pico [role=link].contrast { | |
--pico-color: var(--pico-contrast); | |
--pico-underline: var(--pico-contrast-underline); | |
} | |
.pico :where(a:not([role=button])).contrast:is([aria-current]:not([aria-current=false]), :hover, :active, :focus), | |
.pico [role=link].contrast:is([aria-current]:not([aria-current=false]), :hover, :active, :focus) { | |
--pico-color: var(--pico-contrast-hover); | |
--pico-underline: var(--pico-contrast-hover-underline); | |
} | |
.pico a[role=button] { | |
display: inline-block; | |
} | |
/** | |
* Button | |
*/ | |
.pico button { | |
margin: 0; | |
overflow: visible; | |
font-family: inherit; | |
text-transform: none; | |
} | |
.pico button, | |
.pico [type=submit], | |
.pico [type=reset], | |
.pico [type=button] { | |
-webkit-appearance: button; | |
appearance: button; | |
} | |
.pico button, | |
.pico [type=submit], | |
.pico [type=reset], | |
.pico [type=button], | |
.pico [type=file]::file-selector-button, | |
.pico [role=button] { | |
--pico-background-color: var(--pico-primary-background); | |
--pico-border-color: var(--pico-primary-border); | |
--pico-color: var(--pico-primary-inverse); | |
--pico-box-shadow: var(--pico-button-box-shadow, 0 0 0 rgba(0, 0, 0, 0)); | |
padding: var(--pico-form-element-spacing-vertical) var(--pico-form-element-spacing-horizontal); | |
border: var(--pico-border-width) solid var(--pico-border-color); | |
border-radius: var(--pico-border-radius); | |
outline: none; | |
background-color: var(--pico-background-color); | |
box-shadow: var(--pico-box-shadow); | |
color: var(--pico-color); | |
font-weight: var(--pico-font-weight); | |
font-size: 1rem; | |
line-height: var(--pico-line-height); | |
text-align: center; | |
text-decoration: none; | |
cursor: pointer; | |
-webkit-user-select: none; | |
-moz-user-select: none; | |
user-select: none; | |
transition: background-color var(--pico-transition), border-color var(--pico-transition), color var(--pico-transition), box-shadow var(--pico-transition); | |
} | |
.pico button:is([aria-current]:not([aria-current=false])), | |
.pico button:is(:hover, :active, :focus), | |
.pico [type=submit]:is([aria-current]:not([aria-current=false])), | |
.pico [type=submit]:is(:hover, :active, :focus), | |
.pico [type=reset]:is([aria-current]:not([aria-current=false])), | |
.pico [type=reset]:is(:hover, :active, :focus), | |
.pico [type=button]:is([aria-current]:not([aria-current=false])), | |
.pico [type=button]:is(:hover, :active, :focus), | |
.pico [type=file]::file-selector-button:is([aria-current]:not([aria-current=false])), | |
.pico [type=file]::file-selector-button:is(:hover, :active, :focus), | |
.pico [role=button]:is([aria-current]:not([aria-current=false])), | |
.pico [role=button]:is(:hover, :active, :focus) { | |
--pico-background-color: var(--pico-primary-hover-background); | |
--pico-border-color: var(--pico-primary-hover-border); | |
--pico-box-shadow: var(--pico-button-hover-box-shadow, 0 0 0 rgba(0, 0, 0, 0)); | |
--pico-color: var(--pico-primary-inverse); | |
} | |
.pico button:focus, | |
.pico button:is([aria-current]:not([aria-current=false])):focus, | |
.pico [type=submit]:focus, | |
.pico [type=submit]:is([aria-current]:not([aria-current=false])):focus, | |
.pico [type=reset]:focus, | |
.pico [type=reset]:is([aria-current]:not([aria-current=false])):focus, | |
.pico [type=button]:focus, | |
.pico [type=button]:is([aria-current]:not([aria-current=false])):focus, | |
.pico [type=file]::file-selector-button:focus, | |
.pico [type=file]::file-selector-button:is([aria-current]:not([aria-current=false])):focus, | |
.pico [role=button]:focus, | |
.pico [role=button]:is([aria-current]:not([aria-current=false])):focus { | |
--pico-box-shadow: var(--pico-button-hover-box-shadow, 0 0 0 rgba(0, 0, 0, 0)), 0 0 0 var(--pico-outline-width) var(--pico-primary-focus); | |
} | |
.pico [type=submit], | |
.pico [type=reset], | |
.pico [type=button] { | |
margin-bottom: var(--pico-spacing); | |
} | |
.pico :is(button, [type=submit], [type=button], [role=button]).secondary, | |
.pico [type=reset], | |
.pico [type=file]::file-selector-button { | |
--pico-background-color: var(--pico-secondary-background); | |
--pico-border-color: var(--pico-secondary-border); | |
--pico-color: var(--pico-secondary-inverse); | |
cursor: pointer; | |
} | |
.pico :is(button, [type=submit], [type=button], [role=button]).secondary:is([aria-current]:not([aria-current=false]), :hover, :active, :focus), | |
.pico [type=reset]:is([aria-current]:not([aria-current=false]), :hover, :active, :focus), | |
.pico [type=file]::file-selector-button:is([aria-current]:not([aria-current=false]), :hover, :active, :focus) { | |
--pico-background-color: var(--pico-secondary-hover-background); | |
--pico-border-color: var(--pico-secondary-hover-border); | |
--pico-color: var(--pico-secondary-inverse); | |
} | |
.pico :is(button, [type=submit], [type=button], [role=button]).secondary:focus, | |
.pico :is(button, [type=submit], [type=button], [role=button]).secondary:is([aria-current]:not([aria-current=false])):focus, | |
.pico [type=reset]:focus, | |
.pico [type=reset]:is([aria-current]:not([aria-current=false])):focus, | |
.pico [type=file]::file-selector-button:focus, | |
.pico [type=file]::file-selector-button:is([aria-current]:not([aria-current=false])):focus { | |
--pico-box-shadow: var(--pico-button-hover-box-shadow, 0 0 0 rgba(0, 0, 0, 0)), 0 0 0 var(--pico-outline-width) var(--pico-secondary-focus); | |
} | |
.pico :is(button, [type=submit], [type=button], [role=button]).contrast { | |
--pico-background-color: var(--pico-contrast-background); | |
--pico-border-color: var(--pico-contrast-border); | |
--pico-color: var(--pico-contrast-inverse); | |
} | |
.pico :is(button, [type=submit], [type=button], [role=button]).contrast:is([aria-current]:not([aria-current=false]), :hover, :active, :focus) { | |
--pico-background-color: var(--pico-contrast-hover-background); | |
--pico-border-color: var(--pico-contrast-hover-border); | |
--pico-color: var(--pico-contrast-inverse); | |
} | |
.pico :is(button, [type=submit], [type=button], [role=button]).contrast:focus, | |
.pico :is(button, [type=submit], [type=button], [role=button]).contrast:is([aria-current]:not([aria-current=false])):focus { | |
--pico-box-shadow: var(--pico-button-hover-box-shadow, 0 0 0 rgba(0, 0, 0, 0)), 0 0 0 var(--pico-outline-width) var(--pico-contrast-focus); | |
} | |
.pico :is(button, [type=submit], [type=button], [role=button]).outline, | |
[type=reset].outline { | |
--pico-background-color: transparent; | |
--pico-color: var(--pico-primary); | |
--pico-border-color: var(--pico-primary); | |
} | |
.pico :is(button, [type=submit], [type=button], [role=button]).outline:is([aria-current]:not([aria-current=false]), :hover, :active, :focus), | |
[type=reset].outline:is([aria-current]:not([aria-current=false]), :hover, :active, :focus) { | |
--pico-background-color: transparent; | |
--pico-color: var(--pico-primary-hover); | |
--pico-border-color: var(--pico-primary-hover); | |
} | |
.pico :is(button, [type=submit], [type=button], [role=button]).outline.secondary, | |
[type=reset].outline { | |
--pico-color: var(--pico-secondary); | |
--pico-border-color: var(--pico-secondary); | |
} | |
.pico :is(button, [type=submit], [type=button], [role=button]).outline.secondary:is([aria-current]:not([aria-current=false]), :hover, :active, :focus), | |
[type=reset].outline:is([aria-current]:not([aria-current=false]), :hover, :active, :focus) { | |
--pico-color: var(--pico-secondary-hover); | |
--pico-border-color: var(--pico-secondary-hover); | |
} | |
.pico :is(button, [type=submit], [type=button], [role=button]).outline.contrast { | |
--pico-color: var(--pico-contrast); | |
--pico-border-color: var(--pico-contrast); | |
} | |
.pico :is(button, [type=submit], [type=button], [role=button]).outline.contrast:is([aria-current]:not([aria-current=false]), :hover, :active, :focus) { | |
--pico-color: var(--pico-contrast-hover); | |
--pico-border-color: var(--pico-contrast-hover); | |
} | |
.pico :where(button, [type=submit], [type=reset], [type=button], [role=button])[disabled], | |
.pico :where(fieldset[disabled]) :is(button, [type=submit], [type=button], [type=reset], [role=button]) { | |
opacity: 0.5; | |
pointer-events: none; | |
} | |
/** | |
* Table | |
*/ | |
.pico :where(table) { | |
width: 100%; | |
border-collapse: collapse; | |
border-spacing: 0; | |
text-indent: 0; | |
} | |
.pico th, | |
.pico td { | |
padding: calc(var(--pico-spacing) / 2) var(--pico-spacing); | |
border-bottom: var(--pico-border-width) solid var(--pico-table-border-color); | |
background-color: var(--pico-background-color); | |
color: var(--pico-color); | |
font-weight: var(--pico-font-weight); | |
text-align: left; | |
text-align: start; | |
} | |
.pico tfoot th, | |
.pico tfoot td { | |
border-top: var(--pico-border-width) solid var(--pico-table-border-color); | |
border-bottom: 0; | |
} | |
.pico table.striped tbody tr:nth-child(odd) th, | |
.pico table.striped tbody tr:nth-child(odd) td { | |
background-color: var(--pico-table-row-stripped-background-color); | |
} | |
/** | |
* Embedded content | |
*/ | |
.pico :where(audio, canvas, iframe, img, svg, video) { | |
vertical-align: middle; | |
} | |
.pico audio, | |
.pico video { | |
display: inline-block; | |
} | |
.pico audio:not([controls]) { | |
display: none; | |
height: 0; | |
} | |
.pico :where(iframe) { | |
border-style: none; | |
} | |
.pico img { | |
max-width: 100%; | |
height: auto; | |
border-style: none; | |
} | |
.pico :where(svg:not([fill])) { | |
fill: currentColor; | |
} | |
.pico svg:not(:root) { | |
overflow: hidden; | |
} | |
/** | |
* Code | |
*/ | |
.pico pre, | |
.pico code, | |
.pico kbd, | |
.pico samp { | |
font-size: 0.875em; | |
font-family: var(--pico-font-family); | |
} | |
.pico pre code { | |
font-size: inherit; | |
font-family: inherit; | |
} | |
.pico pre { | |
-ms-overflow-style: scrollbar; | |
overflow: auto; | |
} | |
.pico pre, | |
.pico code, | |
.pico kbd { | |
border-radius: var(--pico-border-radius); | |
background: var(--pico-code-background-color); | |
color: var(--pico-code-color); | |
font-weight: var(--pico-font-weight); | |
line-height: initial; | |
} | |
.pico code, | |
.pico kbd { | |
display: inline-block; | |
padding: 0.375rem; | |
} | |
.pico pre { | |
display: block; | |
margin-bottom: var(--pico-spacing); | |
overflow-x: auto; | |
} | |
.pico pre>code { | |
display: block; | |
padding: var(--pico-spacing); | |
background: none; | |
line-height: var(--pico-line-height); | |
} | |
.pico kbd { | |
background-color: var(--pico-code-kbd-background-color); | |
color: var(--pico-code-kbd-color); | |
vertical-align: baseline; | |
} | |
/** | |
* Figure | |
*/ | |
.pico figure { | |
display: block; | |
margin: 0; | |
padding: 0; | |
} | |
.pico figure figcaption { | |
padding: calc(var(--pico-spacing) * 0.5) 0; | |
color: var(--pico-muted-color); | |
} | |
/** | |
* Miscs | |
*/ | |
.pico hr { | |
height: 0; | |
margin: var(--pico-typography-spacing-vertical) 0; | |
border: 0; | |
border-top: 1px solid var(--pico-muted-border-color); | |
color: inherit; | |
} | |
.pico [hidden], | |
.pico template { | |
display: none !important; | |
} | |
.pico canvas { | |
display: inline-block; | |
} | |
/** | |
* Basics form elements | |
*/ | |
.pico input, | |
.pico optgroup, | |
.pico select, | |
.pico textarea { | |
margin: 0; | |
font-size: 1rem; | |
line-height: var(--pico-line-height); | |
font-family: inherit; | |
letter-spacing: inherit; | |
} | |
.pico input { | |
overflow: visible; | |
} | |
.pico select { | |
text-transform: none; | |
} | |
.pico legend { | |
max-width: 100%; | |
padding: 0; | |
color: inherit; | |
white-space: normal; | |
} | |
.pico textarea { | |
overflow: auto; | |
} | |
.pico [type=checkbox], | |
.pico [type=radio] { | |
padding: 0; | |
} | |
.pico ::-webkit-inner-spin-button, | |
.pico ::-webkit-outer-spin-button { | |
height: auto; | |
} | |
.pico [type=search] { | |
-webkit-appearance: textfield; | |
appearance: textfield; | |
outline-offset: -2px; | |
} | |
.pico [type=search]::-webkit-search-decoration { | |
-webkit-appearance: none; | |
} | |
.pico ::-webkit-file-upload-button { | |
-webkit-appearance: button; | |
font: inherit; | |
} | |
.pico ::-moz-focus-inner { | |
padding: 0; | |
border-style: none; | |
} | |
.pico :-moz-focusring { | |
outline: none; | |
} | |
.pico :-moz-ui-invalid { | |
box-shadow: none; | |
} | |
.pico ::-ms-expand { | |
display: none; | |
} | |
.pico [type=file], | |
.pico [type=range] { | |
padding: 0; | |
border-width: 0; | |
} | |
.pico input:not([type=checkbox], [type=radio], [type=range]) { | |
height: calc(1rem * var(--pico-line-height) + var(--pico-form-element-spacing-vertical) * 2 + var(--pico-border-width) * 2); | |
} | |
.pico fieldset { | |
width: 100%; | |
margin: 0; | |
margin-bottom: var(--pico-spacing); | |
padding: 0; | |
border: 0; | |
} | |
.pico label, | |
.pico fieldset legend { | |
display: block; | |
margin-bottom: calc(var(--pico-spacing) * 0.375); | |
color: var(--pico-color); | |
font-weight: var(--pico-form-label-font-weight, var(--pico-font-weight)); | |
} | |
.pico fieldset legend { | |
margin-bottom: calc(var(--pico-spacing) * 0.5); | |
} | |
.pico input:not([type=checkbox], [type=radio]), | |
.pico button[type=submit], | |
.pico select, | |
.pico textarea { | |
width: 100%; | |
} | |
.pico input:not([type=checkbox], [type=radio], [type=range], [type=file]), | |
.pico select, | |
.pico textarea { | |
-webkit-appearance: none; | |
-moz-appearance: none; | |
appearance: none; | |
padding: var(--pico-form-element-spacing-vertical) var(--pico-form-element-spacing-horizontal); | |
} | |
.pico input, | |
.pico select, | |
.pico textarea { | |
--pico-background-color: var(--pico-form-element-background-color); | |
--pico-border-color: var(--pico-form-element-border-color); | |
--pico-color: var(--pico-form-element-color); | |
--pico-box-shadow: none; | |
border: var(--pico-border-width) solid var(--pico-border-color); | |
border-radius: var(--pico-border-radius); | |
outline: none; | |
background-color: var(--pico-background-color); | |
box-shadow: var(--pico-box-shadow); | |
color: var(--pico-color); | |
font-weight: var(--pico-font-weight); | |
transition: background-color var(--pico-transition), border-color var(--pico-transition), color var(--pico-transition), box-shadow var(--pico-transition); | |
} | |
.pico input:not([type=submit], | |
[type=button], | |
[type=reset], | |
[type=checkbox], | |
[type=radio], | |
[readonly]):is(:active, :focus), | |
.pico :where(select, textarea):not([readonly]):is(:active, :focus) { | |
--pico-background-color: var(--pico-form-element-active-background-color); | |
} | |
.pico input:not([type=submit], [type=button], [type=reset], [role=switch], [readonly]):is(:active, :focus), | |
.pico :where(select, textarea):not([readonly]):is(:active, :focus) { | |
--pico-border-color: var(--pico-form-element-active-border-color); | |
} | |
.pico input:not([type=submit], | |
[type=button], | |
[type=reset], | |
[type=range], | |
[type=file], | |
[readonly]):focus, | |
.pico :where(select, textarea):not([readonly]):focus { | |
--pico-box-shadow: 0 0 0 var(--pico-outline-width) var(--pico-form-element-focus-color); | |
} | |
.pico input:not([type=submit], [type=button], [type=reset])[disabled], | |
.pico select[disabled], | |
.pico textarea[disabled], | |
.pico label[aria-disabled=true], | |
.pico :where(fieldset[disabled]) :is(input:not([type=submit], [type=button], [type=reset]), select, textarea) { | |
opacity: var(--pico-form-element-disabled-opacity); | |
pointer-events: none; | |
} | |
.pico label[aria-disabled=true] input[disabled] { | |
opacity: 1; | |
} | |
.pico :where(input, select, textarea):not([type=checkbox], | |
[type=radio], | |
[type=date], | |
[type=datetime-local], | |
[type=month], | |
[type=time], | |
[type=week], | |
[type=range])[aria-invalid] { | |
padding-right: calc(var(--pico-form-element-spacing-horizontal) + 1.5rem) !important; | |
padding-left: var(--pico-form-element-spacing-horizontal); | |
padding-inline-start: var(--pico-form-element-spacing-horizontal) !important; | |
padding-inline-end: calc(var(--pico-form-element-spacing-horizontal) + 1.5rem) !important; | |
background-position: center right 0.75rem; | |
background-size: 1rem auto; | |
background-repeat: no-repeat; | |
} | |
.pico :where(input, select, textarea):not([type=checkbox], | |
[type=radio], | |
[type=date], | |
[type=datetime-local], | |
[type=month], | |
[type=time], | |
[type=week], | |
[type=range])[aria-invalid=false]:not(select) { | |
background-image: var(--pico-icon-valid); | |
} | |
.pico :where(input, select, textarea):not([type=checkbox], | |
[type=radio], | |
[type=date], | |
[type=datetime-local], | |
[type=month], | |
[type=time], | |
[type=week], | |
[type=range])[aria-invalid=true]:not(select) { | |
background-image: var(--pico-icon-invalid); | |
} | |
.pico :where(input, select, textarea)[aria-invalid=false] { | |
--pico-border-color: var(--pico-form-element-valid-border-color); | |
} | |
.pico :where(input, select, textarea)[aria-invalid=false]:is(:active, :focus) { | |
--pico-border-color: var(--pico-form-element-valid-active-border-color) !important; | |
} | |
.pico :where(input, select, textarea)[aria-invalid=false]:is(:active, :focus):not([type=checkbox], [type=radio]) { | |
--pico-box-shadow: 0 0 0 var(--pico-outline-width) var(--pico-form-element-valid-focus-color) !important; | |
} | |
.pico :where(input, select, textarea)[aria-invalid=true] { | |
--pico-border-color: var(--pico-form-element-invalid-border-color); | |
} | |
.pico :where(input, select, textarea)[aria-invalid=true]:is(:active, :focus) { | |
--pico-border-color: var(--pico-form-element-invalid-active-border-color) !important; | |
} | |
.pico :where(input, select, textarea)[aria-invalid=true]:is(:active, :focus):not([type=checkbox], [type=radio]) { | |
--pico-box-shadow: 0 0 0 var(--pico-outline-width) var(--pico-form-element-invalid-focus-color) !important; | |
} | |
[dir=rtl] .pico :where(input, select, textarea):not([type=checkbox], [type=radio]):is([aria-invalid], [aria-invalid=true], [aria-invalid=false]) { | |
background-position: center left 0.75rem; | |
} | |
.pico input::placeholder, | |
.pico input::-webkit-input-placeholder, | |
.pico textarea::placeholder, | |
.pico textarea::-webkit-input-placeholder, | |
.pico select:invalid { | |
color: var(--pico-form-element-placeholder-color); | |
opacity: 1; | |
} | |
.pico input:not([type=checkbox], [type=radio]), | |
.pico select, | |
.pico textarea { | |
margin-bottom: var(--pico-spacing); | |
} | |
.pico select::-ms-expand { | |
border: 0; | |
background-color: transparent; | |
} | |
.pico select:not([multiple], [size]) { | |
padding-right: calc(var(--pico-form-element-spacing-horizontal) + 1.5rem); | |
padding-left: var(--pico-form-element-spacing-horizontal); | |
padding-inline-start: var(--pico-form-element-spacing-horizontal); | |
padding-inline-end: calc(var(--pico-form-element-spacing-horizontal) + 1.5rem); | |
background-image: var(--pico-icon-chevron); | |
background-position: center right 0.75rem; | |
background-size: 1rem auto; | |
background-repeat: no-repeat; | |
} | |
.pico select[multiple] option:checked { | |
background: var(--pico-form-element-selected-background-color); | |
color: var(--pico-form-element-color); | |
} | |
[dir=rtl] .pico select:not([multiple], [size]) { | |
background-position: center left 0.75rem; | |
} | |
.pico textarea { | |
display: block; | |
resize: vertical; | |
} | |
.pico textarea[aria-invalid] { | |
--pico-icon-height: calc(1rem * var(--pico-line-height) + var(--pico-form-element-spacing-vertical) * 2 + var(--pico-border-width) * 2); | |
background-position: top right 0.75rem !important; | |
background-size: 1rem var(--pico-icon-height) !important; | |
} | |
.pico :where(input, select, textarea, fieldset, .grid)+small { | |
display: block; | |
width: 100%; | |
margin-top: calc(var(--pico-spacing) * -0.75); | |
margin-bottom: var(--pico-spacing); | |
color: var(--pico-muted-color); | |
} | |
.pico :where(input, select, textarea, fieldset, .grid)[aria-invalid=false]+small { | |
color: var(--pico-ins-color); | |
} | |
.pico :where(input, select, textarea, fieldset, .grid)[aria-invalid=true]+small { | |
color: var(--pico-del-color); | |
} | |
.pico label> :where(input, select, textarea) { | |
margin-top: calc(var(--pico-spacing) * 0.25); | |
} | |
/** | |
* Checkboxes, Radios and Switches | |
*/ | |
.pico label:has([type=checkbox], [type=radio]) { | |
width: -moz-fit-content; | |
width: fit-content; | |
cursor: pointer; | |
} | |
.pico [type=checkbox], | |
.pico [type=radio] { | |
-webkit-appearance: none; | |
-moz-appearance: none; | |
appearance: none; | |
width: 1.25em; | |
height: 1.25em; | |
margin-top: -0.125em; | |
margin-inline-end: 0.5em; | |
border-width: var(--pico-border-width); | |
vertical-align: middle; | |
cursor: pointer; | |
} | |
.pico [type=checkbox]::-ms-check, | |
.pico [type=radio]::-ms-check { | |
display: none; | |
} | |
.pico [type=checkbox]:checked, | |
.pico [type=checkbox]:checked:active, | |
.pico [type=checkbox]:checked:focus, | |
.pico [type=radio]:checked, | |
.pico [type=radio]:checked:active, | |
.pico [type=radio]:checked:focus { | |
--pico-background-color: var(--pico-primary-background); | |
--pico-border-color: var(--pico-primary-border); | |
background-image: var(--pico-icon-checkbox); | |
background-position: center; | |
background-size: 0.75em auto; | |
background-repeat: no-repeat; | |
} | |
.pico [type=checkbox]~label, | |
.pico [type=radio]~label { | |
display: inline-block; | |
margin-bottom: 0; | |
cursor: pointer; | |
} | |
.pico [type=checkbox]~label:not(:last-of-type), | |
.pico [type=radio]~label:not(:last-of-type) { | |
margin-inline-end: 1em; | |
} | |
.pico [type=checkbox]:indeterminate { | |
--pico-background-color: var(--pico-primary-background); | |
--pico-border-color: var(--pico-primary-border); | |
background-image: var(--pico-icon-minus); | |
background-position: center; | |
background-size: 0.75em auto; | |
background-repeat: no-repeat; | |
} | |
.pico [type=radio] { | |
border-radius: 50%; | |
} | |
.pico [type=radio]:checked, | |
.pico [type=radio]:checked:active, | |
.pico [type=radio]:checked:focus { | |
--pico-background-color: var(--pico-primary-inverse); | |
border-width: 0.35em; | |
background-image: none; | |
} | |
.pico [type=checkbox][role=switch] { | |
--pico-background-color: var(--pico-switch-background-color); | |
--pico-color: var(--pico-switch-color); | |
width: 2.25em; | |
height: 1.25em; | |
border: var(--pico-border-width) solid var(--pico-border-color); | |
border-radius: 1.25em; | |
background-color: var(--pico-background-color); | |
line-height: 1.25em; | |
} | |
.pico [type=checkbox][role=switch]:not([aria-invalid]) { | |
--pico-border-color: var(--pico-switch-background-color); | |
} | |
.pico [type=checkbox][role=switch]:before { | |
display: block; | |
aspect-ratio: 1; | |
height: 100%; | |
border-radius: 50%; | |
background-color: var(--pico-color); | |
box-shadow: var(--pico-switch-thumb-box-shadow); | |
content: ""; | |
transition: margin 0.1s ease-in-out; | |
} | |
.pico [type=checkbox][role=switch]:focus { | |
--pico-background-color: var(--pico-switch-background-color); | |
--pico-border-color: var(--pico-switch-background-color); | |
} | |
.pico [type=checkbox][role=switch]:checked { | |
--pico-background-color: var(--pico-switch-checked-background-color); | |
--pico-border-color: var(--pico-switch-checked-background-color); | |
background-image: none; | |
} | |
.pico [type=checkbox][role=switch]:checked::before { | |
margin-inline-start: calc(2.25em - 1.25em); | |
} | |
.pico [type=checkbox][role=switch][disabled] { | |
--pico-background-color: var(--pico-border-color); | |
} | |
.pico [type=checkbox][aria-invalid=false]:checked, | |
.pico [type=checkbox][aria-invalid=false]:checked:active, | |
.pico [type=checkbox][aria-invalid=false]:checked:focus, | |
.pico [type=checkbox][role=switch][aria-invalid=false]:checked, | |
.pico [type=checkbox][role=switch][aria-invalid=false]:checked:active, | |
.pico [type=checkbox][role=switch][aria-invalid=false]:checked:focus { | |
--pico-background-color: var(--pico-form-element-valid-border-color); | |
} | |
.pico [type=checkbox]:checked[aria-invalid=true], | |
.pico [type=checkbox]:checked:active[aria-invalid=true], | |
.pico [type=checkbox]:checked:focus[aria-invalid=true], | |
.pico [type=checkbox][role=switch]:checked[aria-invalid=true], | |
.pico [type=checkbox][role=switch]:checked:active[aria-invalid=true], | |
.pico [type=checkbox][role=switch]:checked:focus[aria-invalid=true] { | |
--pico-background-color: var(--pico-form-element-invalid-border-color); | |
} | |
.pico [type=checkbox][aria-invalid=false]:checked, | |
.pico [type=checkbox][aria-invalid=false]:checked:active, | |
.pico [type=checkbox][aria-invalid=false]:checked:focus, | |
.pico [type=radio][aria-invalid=false]:checked, | |
.pico [type=radio][aria-invalid=false]:checked:active, | |
.pico [type=radio][aria-invalid=false]:checked:focus, | |
.pico [type=checkbox][role=switch][aria-invalid=false]:checked, | |
.pico [type=checkbox][role=switch][aria-invalid=false]:checked:active, | |
.pico [type=checkbox][role=switch][aria-invalid=false]:checked:focus { | |
--pico-border-color: var(--pico-form-element-valid-border-color); | |
} | |
.pico [type=checkbox]:checked[aria-invalid=true], | |
.pico [type=checkbox]:checked:active[aria-invalid=true], | |
.pico [type=checkbox]:checked:focus[aria-invalid=true], | |
.pico [type=radio]:checked[aria-invalid=true], | |
.pico [type=radio]:checked:active[aria-invalid=true], | |
.pico [type=radio]:checked:focus[aria-invalid=true], | |
.pico [type=checkbox][role=switch]:checked[aria-invalid=true], | |
.pico [type=checkbox][role=switch]:checked:active[aria-invalid=true], | |
.pico [type=checkbox][role=switch]:checked:focus[aria-invalid=true] { | |
--pico-border-color: var(--pico-form-element-invalid-border-color); | |
} | |
/** | |
* Input type color | |
*/ | |
.pico [type=color]::-webkit-color-swatch-wrapper { | |
padding: 0; | |
} | |
.pico [type=color]::-moz-focus-inner { | |
padding: 0; | |
} | |
.pico [type=color]::-webkit-color-swatch { | |
border: 0; | |
border-radius: calc(var(--pico-border-radius) * 0.5); | |
} | |
.pico [type=color]::-moz-color-swatch { | |
border: 0; | |
border-radius: calc(var(--pico-border-radius) * 0.5); | |
} | |
/** | |
* Input type datetime | |
*/ | |
.pico input:not([type=checkbox], [type=radio], [type=range], [type=file]):is([type=date], [type=datetime-local], [type=month], [type=time], [type=week]) { | |
--pico-icon-position: 0.75rem; | |
--pico-icon-width: 1rem; | |
padding-right: calc(var(--pico-icon-width) + var(--pico-icon-position)); | |
background-image: var(--pico-icon-date); | |
background-position: center right var(--pico-icon-position); | |
background-size: var(--pico-icon-width) auto; | |
background-repeat: no-repeat; | |
} | |
.pico input:not([type=checkbox], [type=radio], [type=range], [type=file])[type=time] { | |
background-image: var(--pico-icon-time); | |
} | |
.pico [type=date]::-webkit-calendar-picker-indicator, | |
.pico [type=datetime-local]::-webkit-calendar-picker-indicator, | |
.pico [type=month]::-webkit-calendar-picker-indicator, | |
.pico [type=time]::-webkit-calendar-picker-indicator, | |
.pico [type=week]::-webkit-calendar-picker-indicator { | |
width: var(--pico-icon-width); | |
margin-right: calc(var(--pico-icon-width) * -1); | |
margin-left: var(--pico-icon-position); | |
opacity: 0; | |
} | |
@-moz-document url-prefix() { | |
.pico [type=date], | |
.pico [type=datetime-local], | |
.pico [type=month], | |
.pico [type=time], | |
.pico [type=week] { | |
padding-right: var(--pico-form-element-spacing-horizontal) !important; | |
background-image: none !important; | |
} | |
} | |
[dir=rtl] .pico :is([type=date], [type=datetime-local], [type=month], [type=time], [type=week]) { | |
text-align: right; | |
} | |
/** | |
* Input type file | |
*/ | |
.pico [type=file] { | |
--pico-color: var(--pico-muted-color); | |
margin-left: calc(var(--pico-outline-width) * -1); | |
padding: calc(var(--pico-form-element-spacing-vertical) * 0.5) 0; | |
padding-left: var(--pico-outline-width); | |
border: 0; | |
border-radius: 0; | |
background: none; | |
} | |
.pico [type=file]::file-selector-button { | |
margin-right: calc(var(--pico-spacing) / 2); | |
padding: calc(var(--pico-form-element-spacing-vertical) * 0.5) var(--pico-form-element-spacing-horizontal); | |
} | |
.pico [type=file]:is(:hover, :active, :focus)::file-selector-button { | |
--pico-background-color: var(--pico-secondary-hover-background); | |
--pico-border-color: var(--pico-secondary-hover-border); | |
} | |
.pico [type=file]:focus::file-selector-button { | |
--pico-box-shadow: var(--pico-button-hover-box-shadow, 0 0 0 rgba(0, 0, 0, 0)), 0 0 0 var(--pico-outline-width) var(--pico-secondary-focus); | |
} | |
/** | |
* Input type range | |
*/ | |
.pico [type=range] { | |
-webkit-appearance: none; | |
-moz-appearance: none; | |
appearance: none; | |
width: 100%; | |
height: 1.25rem; | |
background: none; | |
} | |
.pico [type=range]::-webkit-slider-runnable-track { | |
width: 100%; | |
height: 0.375rem; | |
border-radius: var(--pico-border-radius); | |
background-color: var(--pico-range-border-color); | |
-webkit-transition: background-color var(--pico-transition), box-shadow var(--pico-transition); | |
transition: background-color var(--pico-transition), box-shadow var(--pico-transition); | |
} | |
.pico [type=range]::-moz-range-track { | |
width: 100%; | |
height: 0.375rem; | |
border-radius: var(--pico-border-radius); | |
background-color: var(--pico-range-border-color); | |
-moz-transition: background-color var(--pico-transition), box-shadow var(--pico-transition); | |
transition: background-color var(--pico-transition), box-shadow var(--pico-transition); | |
} | |
.pico [type=range]::-ms-track { | |
width: 100%; | |
height: 0.375rem; | |
border-radius: var(--pico-border-radius); | |
background-color: var(--pico-range-border-color); | |
-ms-transition: background-color var(--pico-transition), box-shadow var(--pico-transition); | |
transition: background-color var(--pico-transition), box-shadow var(--pico-transition); | |
} | |
.pico [type=range]::-webkit-slider-thumb { | |
-webkit-appearance: none; | |
width: 1.25rem; | |
height: 1.25rem; | |
margin-top: -0.4375rem; | |
border: 2px solid var(--pico-range-thumb-border-color); | |
border-radius: 50%; | |
background-color: var(--pico-range-thumb-color); | |
cursor: pointer; | |
-webkit-transition: background-color var(--pico-transition), transform var(--pico-transition); | |
transition: background-color var(--pico-transition), transform var(--pico-transition); | |
} | |
.pico [type=range]::-moz-range-thumb { | |
-webkit-appearance: none; | |
appearance: none; | |
width: 1.25rem; | |
height: 1.25rem; | |
margin-top: -0.4375rem; | |
border: 2px solid var(--pico-range-thumb-border-color); | |
border-radius: 50%; | |
background-color: var(--pico-range-thumb-color); | |
cursor: pointer; | |
-moz-transition: background-color var(--pico-transition), transform var(--pico-transition); | |
transition: background-color var(--pico-transition), transform var(--pico-transition); | |
} | |
.pico [type=range]::-ms-thumb { | |
-webkit-appearance: none; | |
appearance: none; | |
width: 1.25rem; | |
height: 1.25rem; | |
margin-top: -0.4375rem; | |
border: 2px solid var(--pico-range-thumb-border-color); | |
border-radius: 50%; | |
background-color: var(--pico-range-thumb-color); | |
cursor: pointer; | |
-ms-transition: background-color var(--pico-transition), transform var(--pico-transition); | |
transition: background-color var(--pico-transition), transform var(--pico-transition); | |
} | |
.pico [type=range]:active, | |
.pico [type=range]:focus-within { | |
--pico-range-border-color: var(--pico-range-active-border-color); | |
--pico-range-thumb-color: var(--pico-range-thumb-active-color); | |
} | |
.pico [type=range]:active::-webkit-slider-thumb { | |
transform: scale(1.25); | |
} | |
.pico [type=range]:active::-moz-range-thumb { | |
transform: scale(1.25); | |
} | |
.pico [type=range]:active::-ms-thumb { | |
transform: scale(1.25); | |
} | |
/** | |
* Input type search | |
*/ | |
.pico input:not([type=checkbox], [type=radio], [type=range], [type=file])[type=search] { | |
padding-inline-start: calc(var(--pico-form-element-spacing-horizontal) + 1.75rem); | |
background-image: var(--pico-icon-search); | |
background-position: center left calc(var(--pico-form-element-spacing-horizontal) + 0.125rem); | |
background-size: 1rem auto; | |
background-repeat: no-repeat; | |
} | |
.pico input:not([type=checkbox], [type=radio], [type=range], [type=file])[type=search][aria-invalid] { | |
padding-inline-start: calc(var(--pico-form-element-spacing-horizontal) + 1.75rem) !important; | |
background-position: center left 1.125rem, center right 0.75rem; | |
} | |
.pico input:not([type=checkbox], [type=radio], [type=range], [type=file])[type=search][aria-invalid=false] { | |
background-image: var(--pico-icon-search), var(--pico-icon-valid); | |
} | |
.pico input:not([type=checkbox], [type=radio], [type=range], [type=file])[type=search][aria-invalid=true] { | |
background-image: var(--pico-icon-search), var(--pico-icon-invalid); | |
} | |
/** | |
* Accordion (<details>) | |
*/ | |
.pico details { | |
display: block; | |
margin-bottom: var(--pico-spacing); | |
} | |
.pico details summary { | |
line-height: 1rem; | |
list-style-type: none; | |
cursor: pointer; | |
transition: color var(--pico-transition); | |
} | |
.pico details summary:not([role]) { | |
color: var(--pico-accordion-close-summary-color); | |
} | |
.pico details summary::-webkit-details-marker { | |
display: none; | |
} | |
.pico details summary::marker { | |
display: none; | |
} | |
.pico details summary::-moz-list-bullet { | |
list-style-type: none; | |
} | |
.pico details summary::after { | |
display: block; | |
width: 1rem; | |
height: 1rem; | |
margin-inline-start: calc(var(--pico-spacing, 1rem) * 0.5); | |
float: right; | |
transform: rotate(-90deg); | |
background-image: var(--pico-icon-chevron); | |
background-position: right center; | |
background-size: 1rem auto; | |
background-repeat: no-repeat; | |
content: ""; | |
transition: transform var(--pico-transition); | |
} | |
.pico details summary:focus { | |
outline: none; | |
} | |
.pico details summary:focus:not([role]) { | |
color: var(--pico-accordion-active-summary-color); | |
} | |
.pico details summary:focus-visible:not([role]) { | |
outline: var(--pico-outline-width) solid var(--pico-primary-focus); | |
outline-offset: calc(var(--pico-spacing, 1rem) * 0.5); | |
color: var(--pico-primary); | |
} | |
.pico details summary[role=button] { | |
width: 100%; | |
text-align: left; | |
} | |
.pico details summary[role=button]::after { | |
height: calc(1rem * var(--pico-line-height, 1.5)); | |
} | |
.pico details[open]>summary { | |
margin-bottom: var(--pico-spacing); | |
} | |
.pico details[open]>summary:not([role]):not(:focus) { | |
color: var(--pico-accordion-open-summary-color); | |
} | |
.pico details[open]>summary::after { | |
transform: rotate(0); | |
} | |
[dir=rtl] .pico details summary { | |
text-align: right; | |
} | |
[dir=rtl] .pico details summary::after { | |
float: left; | |
background-position: left center; | |
} | |
/** | |
* Card (<article>) | |
*/ | |
.pico article { | |
margin-bottom: var(--pico-block-spacing-vertical); | |
padding: var(--pico-block-spacing-vertical) var(--pico-block-spacing-horizontal); | |
border-radius: var(--pico-border-radius); | |
background: var(--pico-card-background-color); | |
box-shadow: var(--pico-card-box-shadow); | |
} | |
.pico article>header, | |
.pico article>footer { | |
margin-right: calc(var(--pico-block-spacing-horizontal) * -1); | |
margin-left: calc(var(--pico-block-spacing-horizontal) * -1); | |
padding: calc(var(--pico-block-spacing-vertical) * 0.66) var(--pico-block-spacing-horizontal); | |
background-color: var(--pico-card-sectioning-background-color); | |
} | |
.pico article>header { | |
margin-top: calc(var(--pico-block-spacing-vertical) * -1); | |
margin-bottom: var(--pico-block-spacing-vertical); | |
border-bottom: var(--pico-border-width) solid var(--pico-card-border-color); | |
border-top-right-radius: var(--pico-border-radius); | |
border-top-left-radius: var(--pico-border-radius); | |
} | |
.pico article>footer { | |
margin-top: var(--pico-block-spacing-vertical); | |
margin-bottom: calc(var(--pico-block-spacing-vertical) * -1); | |
border-top: var(--pico-border-width) solid var(--pico-card-border-color); | |
border-bottom-right-radius: var(--pico-border-radius); | |
border-bottom-left-radius: var(--pico-border-radius); | |
} | |
/** | |
* Dropdown (details.dropdown) | |
*/ | |
.pico details.dropdown { | |
position: relative; | |
border-bottom: none; | |
} | |
.pico details.dropdown summary::after, | |
.pico details.dropdown>button::after, | |
.pico details.dropdown>a::after { | |
display: block; | |
width: 1rem; | |
height: calc(1rem * var(--pico-line-height, 1.5)); | |
margin-inline-start: 0.25rem; | |
float: right; | |
transform: rotate(0deg) translateX(0.2rem); | |
background-image: var(--pico-icon-chevron); | |
background-position: right center; | |
background-size: 1rem auto; | |
background-repeat: no-repeat; | |
content: ""; | |
} | |
.pico nav details.dropdown { | |
margin-bottom: 0; | |
} | |
.pico details.dropdown summary:not([role]) { | |
height: calc(1rem * var(--pico-line-height) + var(--pico-form-element-spacing-vertical) * 2 + var(--pico-border-width) * 2); | |
padding: var(--pico-form-element-spacing-vertical) var(--pico-form-element-spacing-horizontal); | |
border: var(--pico-border-width) solid var(--pico-form-element-border-color); | |
border-radius: var(--pico-border-radius); | |
background-color: var(--pico-form-element-background-color); | |
color: var(--pico-form-element-placeholder-color); | |
line-height: inherit; | |
cursor: pointer; | |
-webkit-user-select: none; | |
-moz-user-select: none; | |
user-select: none; | |
transition: background-color var(--pico-transition), border-color var(--pico-transition), color var(--pico-transition), box-shadow var(--pico-transition); | |
} | |
.pico details.dropdown summary:not([role]):active, | |
.pico details.dropdown summary:not([role]):focus { | |
border-color: var(--pico-form-element-active-border-color); | |
background-color: var(--pico-form-element-active-background-color); | |
} | |
.pico details.dropdown summary:not([role]):focus { | |
box-shadow: 0 0 0 var(--pico-outline-width) var(--pico-form-element-focus-color); | |
} | |
.pico details.dropdown summary:not([role]):focus-visible { | |
outline: none; | |
} | |
.pico details.dropdown summary:not([role])[aria-invalid=false] { | |
--pico-form-element-border-color: var(--pico-form-element-valid-border-color); | |
--pico-form-element-active-border-color: var(--pico-form-element-valid-focus-color); | |
--pico-form-element-focus-color: var(--pico-form-element-valid-focus-color); | |
} | |
.pico details.dropdown summary:not([role])[aria-invalid=true] { | |
--pico-form-element-border-color: var(--pico-form-element-invalid-border-color); | |
--pico-form-element-active-border-color: var(--pico-form-element-invalid-focus-color); | |
--pico-form-element-focus-color: var(--pico-form-element-invalid-focus-color); | |
} | |
.pico nav details.dropdown { | |
display: inline; | |
margin: calc(var(--pico-nav-element-spacing-vertical) * -1) 0; | |
} | |
.pico nav details.dropdown summary::after { | |
transform: rotate(0deg) translateX(0rem); | |
} | |
.pico nav details.dropdown summary:not([role]) { | |
height: calc(1rem * var(--pico-line-height) + var(--pico-nav-link-spacing-vertical) * 2); | |
padding: calc(var(--pico-nav-link-spacing-vertical) - var(--pico-border-width) * 2) var(--pico-nav-link-spacing-horizontal); | |
} | |
.pico nav details.dropdown summary:not([role]):focus-visible { | |
box-shadow: 0 0 0 var(--pico-outline-width) var(--pico-primary-focus); | |
} | |
.pico details.dropdown summary+ul { | |
display: flex; | |
z-index: 99; | |
position: absolute; | |
left: 0; | |
flex-direction: column; | |
width: 100%; | |
min-width: -moz-fit-content; | |
min-width: fit-content; | |
margin: 0; | |
margin-top: var(--pico-outline-width); | |
padding: 0; | |
border: var(--pico-border-width) solid var(--pico-dropdown-border-color); | |
border-radius: var(--pico-border-radius); | |
background-color: var(--pico-dropdown-background-color); | |
box-shadow: var(--pico-dropdown-box-shadow); | |
color: var(--pico-dropdown-color); | |
white-space: nowrap; | |
opacity: 0; | |
transition: opacity var(--pico-transition), transform 0s ease-in-out 1s; | |
} | |
.pico details.dropdown summary+ul[dir=rtl] { | |
right: 0; | |
left: auto; | |
} | |
.pico details.dropdown summary+ul li { | |
width: 100%; | |
margin-bottom: 0; | |
padding: calc(var(--pico-form-element-spacing-vertical) * 0.5) var(--pico-form-element-spacing-horizontal); | |
list-style: none; | |
} | |
.pico details.dropdown summary+ul li:first-of-type { | |
margin-top: calc(var(--pico-form-element-spacing-vertical) * 0.5); | |
} | |
.pico details.dropdown summary+ul li:last-of-type { | |
margin-bottom: calc(var(--pico-form-element-spacing-vertical) * 0.5); | |
} | |
.pico details.dropdown summary+ul li a { | |
display: block; | |
margin: calc(var(--pico-form-element-spacing-vertical) * -0.5) calc(var(--pico-form-element-spacing-horizontal) * -1); | |
padding: calc(var(--pico-form-element-spacing-vertical) * 0.5) var(--pico-form-element-spacing-horizontal); | |
overflow: hidden; | |
border-radius: 0; | |
color: var(--pico-dropdown-color); | |
text-decoration: none; | |
text-overflow: ellipsis; | |
} | |
.pico details.dropdown summary+ul li a:hover, | |
.pico details.dropdown summary+ul li a:focus, | |
.pico details.dropdown summary+ul li a:active, | |
.pico details.dropdown summary+ul li a:focus-visible, | |
.pico details.dropdown summary+ul li a[aria-current]:not([aria-current=false]) { | |
background-color: var(--pico-dropdown-hover-background-color); | |
} | |
.pico details.dropdown summary+ul li label { | |
width: 100%; | |
} | |
.pico details.dropdown summary+ul li:has(label):hover { | |
background-color: var(--pico-dropdown-hover-background-color); | |
} | |
.pico details.dropdown[open] summary { | |
margin-bottom: 0; | |
} | |
.pico details.dropdown[open] summary+ul { | |
transform: scaleY(1); | |
opacity: 1; | |
transition: opacity var(--pico-transition), transform 0s ease-in-out 0s; | |
} | |
.pico details.dropdown[open] summary::before { | |
display: block; | |
z-index: 1; | |
position: fixed; | |
width: 100vw; | |
height: 100vh; | |
inset: 0; | |
background: none; | |
content: ""; | |
cursor: default; | |
} | |
.pico label>details.dropdown { | |
margin-top: calc(var(--pico-spacing) * 0.25); | |
} | |
/** | |
* Group ([role="group"], [role="search"]) | |
*/ | |
.pico [role=search], | |
.pico [role=group] { | |
display: inline-flex; | |
position: relative; | |
width: 100%; | |
margin-bottom: var(--pico-spacing); | |
border-radius: var(--pico-border-radius); | |
box-shadow: var(--pico-group-box-shadow, 0 0 0 rgba(0, 0, 0, 0)); | |
vertical-align: middle; | |
transition: box-shadow var(--pico-transition); | |
} | |
.pico [role=search]>*, | |
.pico [role=search] input:not([type=checkbox], [type=radio]), | |
.pico [role=search] select, | |
.pico [role=group]>*, | |
.pico [role=group] input:not([type=checkbox], [type=radio]), | |
.pico [role=group] select { | |
position: relative; | |
flex: 1 1 auto; | |
margin-bottom: 0; | |
} | |
.pico [role=search]>*:not(:first-child), | |
.pico [role=search] input:not([type=checkbox], [type=radio]):not(:first-child), | |
.pico [role=search] select:not(:first-child), | |
.pico [role=group]>*:not(:first-child), | |
.pico [role=group] input:not([type=checkbox], [type=radio]):not(:first-child), | |
.pico [role=group] select:not(:first-child) { | |
margin-left: 0; | |
border-top-left-radius: 0; | |
border-bottom-left-radius: 0; | |
} | |
.pico [role=search]>*:not(:last-child), | |
.pico [role=search] input:not([type=checkbox], [type=radio]):not(:last-child), | |
.pico [role=search] select:not(:last-child), | |
.pico [role=group]>*:not(:last-child), | |
.pico [role=group] input:not([type=checkbox], [type=radio]):not(:last-child), | |
.pico [role=group] select:not(:last-child) { | |
border-top-right-radius: 0; | |
border-bottom-right-radius: 0; | |
} | |
.pico [role=search]>*:focus, | |
.pico [role=search] input:not([type=checkbox], [type=radio]):focus, | |
.pico [role=search] select:focus, | |
.pico [role=group]>*:focus, | |
.pico [role=group] input:not([type=checkbox], [type=radio]):focus, | |
.pico [role=group] select:focus { | |
z-index: 2; | |
} | |
.pico [role=search] button:not(:first-child), | |
.pico [role=search] [type=submit]:not(:first-child), | |
.pico [role=search] [type=reset]:not(:first-child), | |
.pico [role=search] [type=button]:not(:first-child), | |
.pico [role=search] [role=button]:not(:first-child), | |
.pico [role=search] input:not([type=checkbox], [type=radio]):not(:first-child), | |
.pico [role=search] select:not(:first-child), | |
.pico [role=group] button:not(:first-child), | |
.pico [role=group] [type=submit]:not(:first-child), | |
.pico [role=group] [type=reset]:not(:first-child), | |
.pico [role=group] [type=button]:not(:first-child), | |
.pico [role=group] [role=button]:not(:first-child), | |
.pico [role=group] input:not([type=checkbox], [type=radio]):not(:first-child), | |
.pico [role=group] select:not(:first-child) { | |
margin-left: calc(var(--pico-border-width) * -1); | |
} | |
.pico [role=search] button, | |
.pico [role=search] [type=submit], | |
.pico [role=search] [type=reset], | |
.pico [role=search] [type=button], | |
.pico [role=search] [role=button], | |
.pico [role=group] button, | |
.pico [role=group] [type=submit], | |
.pico [role=group] [type=reset], | |
.pico [role=group] [type=button], | |
.pico [role=group] [role=button] { | |
width: auto; | |
} | |
@supports selector(:has(*)) { | |
.pico [role=search]:has(button:focus, [type=submit]:focus, [type=button]:focus, [role=button]:focus), | |
.pico [role=group]:has(button:focus, [type=submit]:focus, [type=button]:focus, [role=button]:focus) { | |
--pico-group-box-shadow: var(--pico-group-box-shadow-focus-with-button); | |
} | |
.pico [role=search]:has(button:focus, [type=submit]:focus, [type=button]:focus, [role=button]:focus) input:not([type=checkbox], [type=radio]), | |
.pico [role=search]:has(button:focus, [type=submit]:focus, [type=button]:focus, [role=button]:focus) select, | |
.pico [role=group]:has(button:focus, [type=submit]:focus, [type=button]:focus, [role=button]:focus) input:not([type=checkbox], [type=radio]), | |
.pico [role=group]:has(button:focus, [type=submit]:focus, [type=button]:focus, [role=button]:focus) select { | |
border-color: transparent; | |
} | |
.pico [role=search]:has(input:not([type=submit], [type=button]):focus, select:focus), | |
.pico [role=group]:has(input:not([type=submit], [type=button]):focus, select:focus) { | |
--pico-group-box-shadow: var(--pico-group-box-shadow-focus-with-input); | |
} | |
.pico [role=search]:has(input:not([type=submit], [type=button]):focus, select:focus) button, | |
.pico [role=search]:has(input:not([type=submit], [type=button]):focus, select:focus) [type=submit], | |
.pico [role=search]:has(input:not([type=submit], [type=button]):focus, select:focus) [type=button], | |
.pico [role=search]:has(input:not([type=submit], [type=button]):focus, select:focus) [role=button], | |
.pico [role=group]:has(input:not([type=submit], [type=button]):focus, select:focus) button, | |
.pico [role=group]:has(input:not([type=submit], [type=button]):focus, select:focus) [type=submit], | |
.pico [role=group]:has(input:not([type=submit], [type=button]):focus, select:focus) [type=button], | |
.pico [role=group]:has(input:not([type=submit], [type=button]):focus, select:focus) [role=button] { | |
--pico-button-box-shadow: 0 0 0 var(--pico-border-width) var(--pico-primary-border); | |
--pico-button-hover-box-shadow: 0 0 0 var(--pico-border-width) var(--pico-primary-hover-border); | |
} | |
.pico [role=search] button:focus, | |
.pico [role=search] [type=submit]:focus, | |
.pico [role=search] [type=reset]:focus, | |
.pico [role=search] [type=button]:focus, | |
.pico [role=search] [role=button]:focus, | |
.pico [role=group] button:focus, | |
.pico [role=group] [type=submit]:focus, | |
.pico [role=group] [type=reset]:focus, | |
.pico [role=group] [type=button]:focus, | |
.pico [role=group] [role=button]:focus { | |
box-shadow: none; | |
} | |
} | |
.pico [role=search]>*:first-child { | |
border-top-left-radius: 5rem; | |
border-bottom-left-radius: 5rem; | |
} | |
.pico [role=search]>*:last-child { | |
border-top-right-radius: 5rem; | |
border-bottom-right-radius: 5rem; | |
} | |
/** | |
* Loading ([aria-busy=true]) | |
*/ | |
.pico [aria-busy=true]:not(input, select, textarea, html) { | |
white-space: nowrap; | |
} | |
.pico [aria-busy=true]:not(input, select, textarea, html)::before { | |
display: inline-block; | |
width: 1em; | |
height: 1em; | |
background-image: var(--pico-icon-loading); | |
background-size: 1em auto; | |
background-repeat: no-repeat; | |
content: ""; | |
vertical-align: -0.125em; | |
} | |
.pico [aria-busy=true]:not(input, select, textarea, html):not(:empty)::before { | |
margin-inline-end: calc(var(--pico-spacing) * 0.5); | |
} | |
.pico [aria-busy=true]:not(input, select, textarea, html):empty { | |
text-align: center; | |
} | |
.pico button[aria-busy=true], | |
.pico [type=submit][aria-busy=true], | |
.pico [type=button][aria-busy=true], | |
.pico [type=reset][aria-busy=true], | |
.pico [role=button][aria-busy=true], | |
.pico a[aria-busy=true] { | |
pointer-events: none; | |
} | |
/** | |
* Modal (<dialog>) | |
*/ | |
:root { | |
--pico-scrollbar-width: 0px; | |
} | |
.pico dialog { | |
display: flex; | |
z-index: 999; | |
position: fixed; | |
top: 0; | |
right: 0; | |
bottom: 0; | |
left: 0; | |
align-items: center; | |
justify-content: center; | |
width: inherit; | |
min-width: 100%; | |
height: inherit; | |
min-height: 100%; | |
padding: 0; | |
border: 0; | |
-webkit-backdrop-filter: var(--pico-modal-overlay-backdrop-filter); | |
backdrop-filter: var(--pico-modal-overlay-backdrop-filter); | |
background-color: var(--pico-modal-overlay-background-color); | |
color: var(--pico-color); | |
} | |
.pico dialog article { | |
width: 100%; | |
max-height: calc(100vh - var(--pico-spacing) * 2); | |
margin: var(--pico-spacing); | |
overflow: auto; | |
} | |
@media (min-width: 576px) { | |
.pico dialog article { | |
max-width: 510px; | |
} | |
} | |
@media (min-width: 768px) { | |
.pico dialog article { | |
max-width: 700px; | |
} | |
} | |
.pico dialog article>header>* { | |
margin-bottom: 0; | |
} | |
.pico dialog article>header .close, | |
.pico dialog article>header :is(a, button)[rel=prev] { | |
margin: 0; | |
margin-left: var(--pico-spacing); | |
padding: 0; | |
float: right; | |
} | |
.pico dialog article>footer { | |
text-align: right; | |
} | |
.pico dialog article>footer button, | |
.pico dialog article>footer [role=button] { | |
margin-bottom: 0; | |
} | |
.pico dialog article>footer button:not(:first-of-type), | |
.pico dialog article>footer [role=button]:not(:first-of-type) { | |
margin-left: calc(var(--pico-spacing) * 0.5); | |
} | |
.pico dialog article .close, | |
.pico dialog article :is(a, button)[rel=prev] { | |
display: block; | |
width: 1rem; | |
height: 1rem; | |
margin-top: calc(var(--pico-spacing) * -1); | |
margin-bottom: var(--pico-spacing); | |
margin-left: auto; | |
border: none; | |
background-image: var(--pico-icon-close); | |
background-position: center; | |
background-size: auto 1rem; | |
background-repeat: no-repeat; | |
background-color: transparent; | |
opacity: 0.5; | |
transition: opacity var(--pico-transition); | |
} | |
.pico dialog article .close:is([aria-current]:not([aria-current=false]), :hover, :active, :focus), | |
.pico dialog article :is(a, button)[rel=prev]:is([aria-current]:not([aria-current=false]), :hover, :active, :focus) { | |
opacity: 1; | |
} | |
.pico dialog:not([open]), | |
.pico dialog[open=false] { | |
display: none; | |
} | |
.modal-is-open { | |
padding-right: var(--pico-scrollbar-width, 0px); | |
overflow: hidden; | |
pointer-events: none; | |
touch-action: none; | |
} | |
.modal-is-open dialog { | |
pointer-events: auto; | |
touch-action: auto; | |
} | |
:where(.modal-is-opening, .modal-is-closing) dialog, | |
:where(.modal-is-opening, .modal-is-closing) dialog>article { | |
animation-duration: 0.2s; | |
animation-timing-function: ease-in-out; | |
animation-fill-mode: both; | |
} | |
:where(.modal-is-opening, .modal-is-closing) dialog { | |
animation-duration: 0.8s; | |
animation-name: modal-overlay; | |
} | |
:where(.modal-is-opening, .modal-is-closing) dialog>article { | |
animation-delay: 0.2s; | |
animation-name: modal; | |
} | |
.modal-is-closing dialog, | |
.modal-is-closing dialog>article { | |
animation-delay: 0s; | |
animation-direction: reverse; | |
} | |
@keyframes modal-overlay { | |
from { | |
-webkit-backdrop-filter: none; | |
backdrop-filter: none; | |
background-color: transparent; | |
} | |
} | |
@keyframes modal { | |
from { | |
transform: translateY(-100%); | |
opacity: 0; | |
} | |
} | |
/** | |
* Nav | |
*/ | |
.pico :where(nav li)::before { | |
float: left; | |
content: ""; | |
} | |
.pico nav, | |
.pico nav ul { | |
display: flex; | |
} | |
.pico nav { | |
justify-content: space-between; | |
overflow: visible; | |
} | |
.pico nav ol, | |
.pico nav ul { | |
align-items: center; | |
margin-bottom: 0; | |
padding: 0; | |
list-style: none; | |
} | |
.pico nav ol:first-of-type, | |
.pico nav ul:first-of-type { | |
margin-left: calc(var(--pico-nav-element-spacing-horizontal) * -1); | |
} | |
.pico nav ol:last-of-type, | |
.pico nav ul:last-of-type { | |
margin-right: calc(var(--pico-nav-element-spacing-horizontal) * -1); | |
} | |
.pico nav li { | |
display: inline-block; | |
margin: 0; | |
padding: var(--pico-nav-element-spacing-vertical) var(--pico-nav-element-spacing-horizontal); | |
} | |
.pico nav li :where(a, [role=link]) { | |
display: inline-block; | |
margin: calc(var(--pico-nav-link-spacing-vertical) * -1) calc(var(--pico-nav-link-spacing-horizontal) * -1); | |
padding: var(--pico-nav-link-spacing-vertical) var(--pico-nav-link-spacing-horizontal); | |
border-radius: var(--pico-border-radius); | |
} | |
.pico nav li :where(a, [role=link]):not(:hover) { | |
text-decoration: none; | |
} | |
.pico nav li button, | |
.pico nav li [role=button], | |
.pico nav li [type=button], | |
.pico nav li input:not([type=checkbox], [type=radio], [type=range], [type=file]), | |
.pico nav li select { | |
height: auto; | |
margin-right: inherit; | |
margin-bottom: 0; | |
margin-left: inherit; | |
padding: calc(var(--pico-nav-link-spacing-vertical) - var(--pico-border-width) * 2) var(--pico-nav-link-spacing-horizontal); | |
} | |
.pico nav[aria-label=breadcrumb] { | |
align-items: center; | |
justify-content: start; | |
} | |
.pico nav[aria-label=breadcrumb] ul li:not(:first-child) { | |
margin-inline-start: var(--pico-nav-link-spacing-horizontal); | |
} | |
.pico nav[aria-label=breadcrumb] ul li a { | |
margin: calc(var(--pico-nav-link-spacing-vertical) * -1) 0; | |
margin-inline-start: calc(var(--pico-nav-link-spacing-horizontal) * -1); | |
} | |
.pico nav[aria-label=breadcrumb] ul li:not(:last-child)::after { | |
display: inline-block; | |
position: absolute; | |
width: calc(var(--pico-nav-link-spacing-horizontal) * 4); | |
margin: 0 calc(var(--pico-nav-link-spacing-horizontal) * -1); | |
content: var(--pico-nav-breadcrumb-divider); | |
color: var(--pico-muted-color); | |
text-align: center; | |
text-decoration: none; | |
white-space: nowrap; | |
} | |
.pico nav[aria-label=breadcrumb] a[aria-current]:not([aria-current=false]) { | |
background-color: transparent; | |
color: inherit; | |
text-decoration: none; | |
pointer-events: none; | |
} | |
.pico aside nav, | |
.pico aside ol, | |
.pico aside ul, | |
.pico aside li { | |
display: block; | |
} | |
.pico aside li { | |
padding: calc(var(--pico-nav-element-spacing-vertical) * 0.5) var(--pico-nav-element-spacing-horizontal); | |
} | |
.pico aside li a { | |
display: block; | |
} | |
.pico aside li [role=button] { | |
margin: inherit; | |
} | |
[dir=rtl] .pico nav[aria-label=breadcrumb] ul li:not(:last-child) ::after { | |
content: "\\"; | |
} | |
/** | |
* Progress | |
*/ | |
.pico progress { | |
display: inline-block; | |
vertical-align: baseline; | |
} | |
.pico progress { | |
-webkit-appearance: none; | |
-moz-appearance: none; | |
display: inline-block; | |
appearance: none; | |
width: 100%; | |
height: 0.5rem; | |
margin-bottom: calc(var(--pico-spacing) * 0.5); | |
overflow: hidden; | |
border: 0; | |
border-radius: var(--pico-border-radius); | |
background-color: var(--pico-progress-background-color); | |
color: var(--pico-progress-color); | |
} | |
.pico progress::-webkit-progress-bar { | |
border-radius: var(--pico-border-radius); | |
background: none; | |
} | |
.pico progress[value]::-webkit-progress-value { | |
background-color: var(--pico-progress-color); | |
-webkit-transition: inline-size var(--pico-transition); | |
transition: inline-size var(--pico-transition); | |
} | |
.pico progress::-moz-progress-bar { | |
background-color: var(--pico-progress-color); | |
} | |
@media (prefers-reduced-motion: no-preference) { | |
.pico progress:indeterminate { | |
background: var(--pico-progress-background-color) linear-gradient(to right, var(--pico-progress-color) 30%, var(--pico-progress-background-color) 30%) top left/150% 150% no-repeat; | |
animation: progress-indeterminate 1s linear infinite; | |
} | |
.pico progress:indeterminate[value]::-webkit-progress-value { | |
background-color: transparent; | |
} | |
.pico progress:indeterminate::-moz-progress-bar { | |
background-color: transparent; | |
} | |
} | |
@media (prefers-reduced-motion: no-preference) { | |
[dir=rtl] .pico progress:indeterminate { | |
animation-direction: reverse; | |
} | |
} | |
@keyframes progress-indeterminate { | |
0% { | |
background-position: 200% 0; | |
} | |
100% { | |
background-position: -200% 0; | |
} | |
} | |
/** | |
* Tooltip ([data-tooltip]) | |
*/ | |
.pico [data-tooltip] { | |
position: relative; | |
} | |
.pico [data-tooltip]:not(a, button, input) { | |
border-bottom: 1px dotted; | |
text-decoration: none; | |
cursor: help; | |
} | |
.pico [data-tooltip][data-placement=top]::before, | |
.pico [data-tooltip][data-placement=top]::after, | |
.pico [data-tooltip]::before, | |
.pico [data-tooltip]::after { | |
display: block; | |
z-index: 99; | |
position: absolute; | |
bottom: 100%; | |
left: 50%; | |
padding: 0.25rem 0.5rem; | |
overflow: hidden; | |
transform: translate(-50%, -0.25rem); | |
border-radius: var(--pico-border-radius); | |
background: var(--pico-tooltip-background-color); | |
content: attr(data-tooltip); | |
color: var(--pico-tooltip-color); | |
font-style: normal; | |
font-weight: var(--pico-font-weight); | |
font-size: 0.875rem; | |
text-decoration: none; | |
text-overflow: ellipsis; | |
white-space: nowrap; | |
opacity: 0; | |
pointer-events: none; | |
} | |
.pico [data-tooltip][data-placement=top]::after, | |
.pico [data-tooltip]::after { | |
padding: 0; | |
transform: translate(-50%, 0rem); | |
border-top: 0.3rem solid; | |
border-right: 0.3rem solid transparent; | |
border-left: 0.3rem solid transparent; | |
border-radius: 0; | |
background-color: transparent; | |
content: ""; | |
color: var(--pico-tooltip-background-color); | |
} | |
.pico [data-tooltip][data-placement=bottom]::before, | |
.pico [data-tooltip][data-placement=bottom]::after { | |
top: 100%; | |
bottom: auto; | |
transform: translate(-50%, 0.25rem); | |
} | |
.pico [data-tooltip][data-placement=bottom]:after { | |
transform: translate(-50%, -0.3rem); | |
border: 0.3rem solid transparent; | |
border-bottom: 0.3rem solid; | |
} | |
.pico [data-tooltip][data-placement=left]::before, | |
.pico [data-tooltip][data-placement=left]::after { | |
top: 50%; | |
right: 100%; | |
bottom: auto; | |
left: auto; | |
transform: translate(-0.25rem, -50%); | |
} | |
.pico [data-tooltip][data-placement=left]:after { | |
transform: translate(0.3rem, -50%); | |
border: 0.3rem solid transparent; | |
border-left: 0.3rem solid; | |
} | |
.pico [data-tooltip][data-placement=right]::before, | |
.pico [data-tooltip][data-placement=right]::after { | |
top: 50%; | |
right: auto; | |
bottom: auto; | |
left: 100%; | |
transform: translate(0.25rem, -50%); | |
} | |
.pico [data-tooltip][data-placement=right]:after { | |
transform: translate(-0.3rem, -50%); | |
border: 0.3rem solid transparent; | |
border-right: 0.3rem solid; | |
} | |
.pico [data-tooltip]:focus::before, | |
.pico [data-tooltip]:focus::after, | |
.pico [data-tooltip]:hover::before, | |
.pico [data-tooltip]:hover::after { | |
opacity: 1; | |
} | |
@media (hover: hover) and (pointer: fine) { | |
.pico [data-tooltip]:focus::before, | |
.pico [data-tooltip]:focus::after, | |
.pico [data-tooltip]:hover::before, | |
.pico [data-tooltip]:hover::after { | |
--pico-tooltip-slide-to: translate(-50%, -0.25rem); | |
transform: translate(-50%, 0.75rem); | |
animation-duration: 0.2s; | |
animation-fill-mode: forwards; | |
animation-name: tooltip-slide; | |
opacity: 0; | |
} | |
.pico [data-tooltip]:focus::after, | |
.pico [data-tooltip]:hover::after { | |
--pico-tooltip-caret-slide-to: translate(-50%, 0rem); | |
transform: translate(-50%, -0.25rem); | |
animation-name: tooltip-caret-slide; | |
} | |
.pico [data-tooltip][data-placement=bottom]:focus::before, | |
.pico [data-tooltip][data-placement=bottom]:focus::after, | |
.pico [data-tooltip][data-placement=bottom]:hover::before, | |
.pico [data-tooltip][data-placement=bottom]:hover::after { | |
--pico-tooltip-slide-to: translate(-50%, 0.25rem); | |
transform: translate(-50%, -0.75rem); | |
animation-name: tooltip-slide; | |
} | |
.pico [data-tooltip][data-placement=bottom]:focus::after, | |
.pico [data-tooltip][data-placement=bottom]:hover::after { | |
--pico-tooltip-caret-slide-to: translate(-50%, -0.3rem); | |
transform: translate(-50%, -0.5rem); | |
animation-name: tooltip-caret-slide; | |
} | |
.pico [data-tooltip][data-placement=left]:focus::before, | |
.pico [data-tooltip][data-placement=left]:focus::after, | |
.pico [data-tooltip][data-placement=left]:hover::before, | |
.pico [data-tooltip][data-placement=left]:hover::after { | |
--pico-tooltip-slide-to: translate(-0.25rem, -50%); | |
transform: translate(0.75rem, -50%); | |
animation-name: tooltip-slide; | |
} | |
.pico [data-tooltip][data-placement=left]:focus::after, | |
.pico [data-tooltip][data-placement=left]:hover::after { | |
--pico-tooltip-caret-slide-to: translate(0.3rem, -50%); | |
transform: translate(0.05rem, -50%); | |
animation-name: tooltip-caret-slide; | |
} | |
.pico [data-tooltip][data-placement=right]:focus::before, | |
.pico [data-tooltip][data-placement=right]:focus::after, | |
.pico [data-tooltip][data-placement=right]:hover::before, | |
.pico [data-tooltip][data-placement=right]:hover::after { | |
--pico-tooltip-slide-to: translate(0.25rem, -50%); | |
transform: translate(-0.75rem, -50%); | |
animation-name: tooltip-slide; | |
} | |
.pico [data-tooltip][data-placement=right]:focus::after, | |
.pico [data-tooltip][data-placement=right]:hover::after { | |
--pico-tooltip-caret-slide-to: translate(-0.3rem, -50%); | |
transform: translate(-0.05rem, -50%); | |
animation-name: tooltip-caret-slide; | |
} | |
} | |
@keyframes tooltip-slide { | |
to { | |
transform: var(--pico-tooltip-slide-to); | |
opacity: 1; | |
} | |
} | |
@keyframes tooltip-caret-slide { | |
50% { | |
opacity: 0; | |
} | |
to { | |
transform: var(--pico-tooltip-caret-slide-to); | |
opacity: 1; | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment