/* Devquarium Design System v1 */

:root{

    /* Colors */
    --black: #242424;
    --white: #fff;
    --back: hsl(0 0% 10% / 1);
    --system: hsl(230deg 5% 50%);

    --primary: hsl(200 80% 50% / 1);
    --primary-light: hsl(200 80% 55% / 1);
    --primary-dark: hsl(200 80% 45% / 1);
    
    --secondary: hsl(205deg 50% 55%);
    --secondary-light: hsl(205deg 50% 60%);
    --secondary-dark: hsl(205deg 50% 50%);

    --success: hsl(125deg 45% 50%);
    --success-light: hsl(125, 45%, 55%);
    --success-dark: hsl(125, 45%, 45%);

    --danger: hsl(0deg 85% 62%);
    --danger-light: hsl(0deg 85% 67%);
    --danger-dark: hsl(0deg 85% 57%);

    --warning: hsl(40deg 100% 53%);
    --warning-light: hsl(40deg 100% 58%);
    --warning-dark: hsl(40deg 100% 48%);


    --dark: hsl(0deg 0% 20%);
    --dark-light: hsl(0deg 0% 25%);
    --dark-dark: hsl(0deg 0% 15%);

    --light: hsl(0deg 0% 80%);
    --light-light: hsl(0deg 0% 85%);
    --light-dark: hsl(0deg 0% 75%);
    
    --grad1: hsl(0deg 0% 80%);
    --grad2: hsl(0deg 0% 60%);
    --grad3: hsl(0deg 0% 40%);
    --grad4: hsl(0deg 0% 20%);
    --grad5: hsl(0deg 0% 10%);


    /* --dark: hsl(0deg 0% 90%);
    --dark-light: hsl(0deg 0% 95%);
    --dark-dark: hsl(0deg 0% 85%); */

    --shine: rgba(255,255,255,0.15);
    /* --shade: rgba(0,0,0,0.07);
    --shadow: rgba(0,0,0,0.15); */
    --shade: hsl(0deg 0% 100% / 5%);
    --shadow: rgba(0,0,0,0.25);

    /* External */
    --google-icon: "Material Symbols Outlined";

    /* Config */
    --base-radius: 0.25rem;
    --grid-gap: 1rem;

}

body{
    margin:0;
    font-family: sans-serif;
    background-color: var(--back);
    color: var(--white);
}


a {
    color: var(--primary);
}


.dq-item {
    transition: 0.1s;
    border-radius: var(--base-radius);
    display: grid;
    grid-auto-flow: column;
    justify-content: start;
    align-items: center;
    grid-gap: 1rem;
    height: 40px;
}



.dq-btn {
    --radius: var(--base-radius);
    --color: var(--primary);
    --color-light: var(--primary-light);
    --color-dark: var(--primary-dark);
    padding: 8px 12px;
    background: var(--color);
    display: inline-grid;
    grid-auto-flow: column;
    color: var(--black);
    border-radius: var(--radius);
    cursor: pointer;
    transition: 0.1s;
    user-select: none;
    outline: none;
    text-decoration: none;
    font-size: 15px;
    text-align: center;
    line-height: 24px;
    box-sizing: border-box;
    border: none;
    justify-content: center;
    align-items: center;
    justify-items: center;
    grid-gap: 0.5rem;
    vertical-align: middle;
    position: relative;
    width: fit-content;
}

@media (hover: hover) {
    .dq-btn:hover {
        background-color: var(--color-light);
    }
}
.dq-btn:active {
    background-color: var(--color-dark);
}

.dq-btn.-outline {
    background: none !important;
    box-shadow: inset  0 0 0 1px;
    color: var(--color);
}
.dq-btn.-outline:hover {
    color: var(--color-light);
}
.dq-btn.-outline:active {
    color: var(--color-dark);
}

.dq-btn.-flat {
    background: none;
    box-shadow: none;
    color: var(--color);
    font-weight: bold;
}

@media (hover: hover) {
    .dq-btn.-flat:hover {
        color: var(--color-light);
        background-color: var(--shade);
    }
}
.dq-btn.-flat:active {
    color: var(--color-dark);
    background-color: var(--shadow);
}
.dq-btn.-flat.-ripple:active {
    background: var(--shade) !important;
}

.dq-btn.-full {
    width:100%;
}

.dq-btn.-round {
    border-radius: 100px;
}

.dq-btn.-icon, .dq-btn.dq-icon {
    padding: 6px 6px;
}

.dq-btn .dq-icon {
    vertical-align: bottom;
}
.dq-btn .dq-icon.-start {
    float: left;
    text-align: left;
    margin-right: 0.25rem;
}
.dq-btn .dq-icon.-end {
    float: right;
    text-align: right;
    margin-left: 0.25rem;
}

.dq-btn[disabled] {
    pointer-events: none;
    background: var(--grad3);
}

.dq-btn.-small {
    padding: 0.2rem 0.5rem;
    height: 30px;
    font-size: 14px;
}

.dq-btn.-small.-icon, .dq-btn.-small.dq-icon {
    padding: 0.2rem;
    height: 30px;
    width: 30px;
    font-size: 14px;
}

.dq-btn.-small.dq-icon {
    font-size: 18px;
    line-height: calc(30px - 0.4rem);
}
.dq-btn.-small .dq-icon {
    font-size: 18px;
    
}

.dq-btn.-ripple:not(:active):after {
    content: "";
    width: 100%;
    aspect-ratio: 1/1;
    position: absolute;
    background: var(--color-light);
    filter: saturate(0.5) opacity(0.25) brightness(1.5);
    border-radius: 80px;
    animation: ripple 0.55s forwards;
    visibility: hidden;
    transition-delay: 0.55s;
    transition-property: visibility;
}
.dq-btn.-ripple:active {
    background-color: var(--color-light);
}
.dq-btn.-ripple {
    overflow: hidden;
}

.dq-btn.-ripple:hover:after {
    opacity: 1;
    visibility: visible;
}

/* Accessiblity */
.dq-btn:focus {
    outline: 1px solid var(--color);
}

@keyframes ripple {
    0%{transform: scale(0);}
    50%{opacity: 1}
    100%{transform: scale(1.25);opacity: 0;}
}

.dq-icon{
    font-family: var(--google-icon);
    font-weight: normal;
    font-style: normal;
    font-size: 24px;
    line-height: 1;
    letter-spacing: normal;
    text-transform: none;
    display: inline-block;
    white-space: nowrap;
    word-wrap: normal;
    direction: ltr;
    -webkit-font-feature-settings: 'liga';
    -webkit-font-smoothing: antialiased;
    user-select: none;
}
.dq-icon.-inherit{
    font-size: inherit;
}
.dq-icon.-small{
    font-size: 18px;
}


.dq-bloc {
    background: var(--black);
    margin: auto;
    padding: 1rem;
    box-shadow: 0 0.5rem 1rem var(--shadow);
    border-radius: calc(var(--base-radius) * 2);
}

.dq-bloc.-full{
    width:100%;
    height: 100%;
}


/* TEXTAREA */
.dq-textarea {
    --color: var(--primary);
    --color-dark: var(--primary-dark);
    font-family: inherit;
    outline: none;
    padding: 0.5rem;
    box-sizing: border-box;
    border: none;
    border-radius: var(--base-radius);
    background: var(--shade);
    /* box-shadow: inset 0px 0 2px var(--shade); */
    font-size: .82rem;
    transition: 0.05s;
    color: var(--white);
    height: 40px;
    min-width: 10px;
}

.dq-textarea.-full {
    display: block;
    width: 100%;
}

.dq-textarea:focus {
    box-shadow: inset 0 0 0 1px var(--color);
}

.dq-textarea.-outline {
    background: none;
    box-shadow: inset 0 0 0 1px var(--system);
}

.dq-textarea.-outline:focus {
    box-shadow: inset 0 0 0 1px var(--color);
}


/* INPUTS */
input {
    --color: var(--primary);
    --color-dark: var(--primary-dark);
    font-family: inherit;
    outline: none;
    padding: 0.5rem;
    box-sizing: border-box;
    border: none;
    border-radius: var(--base-radius);
    background: var(--shade);
    /* box-shadow: inset 0px 0 2px var(--shade); */
    font-size: .82rem;
    transition: 0.05s;
    color: var(--white);
    height: 40px;
    min-width: 10px;
}

input.-full {
    display: block;
    width: 100%;
}

input:focus {
    box-shadow: inset 0 0 0 1px var(--color);
}

input.-outline {
    background: none;
    box-shadow: inset 0 0 0 1px var(--system);
}

input.-outline:focus {
    box-shadow: inset 0 0 0 1px var(--color);
}

/* dq-input */
.dq-input {
    --color: var(--primary);
    font-family: inherit;
    outline: none;
    box-sizing: border-box;
    border: none;
    border-radius: var(--base-radius);
    background: var(--shade);
    /* box-shadow: inset 0px 0 2px var(--shade); */
    display: inline-flex;
    align-items: center;
    vertical-align: middle;
    transition: 0.05s;
    max-height: 40px;
}

.dq-input.-full {
    display: flex;
}

.dq-input input, .dq-input select {
    font-family: inherit;
    box-shadow: none;
    background: none;
    padding: 0.5rem;
    flex: 1;
}

.dq-input > .dq-icon, .dq-input .dq-text {
    padding: 0.5rem;
    color: var(--system);
    user-select: none;
    padding-right: 0rem;
    transition: 0.05s;
}
.dq-input .dq-text {
    font-size: 12px;
}
.dq-input input + .dq-icon, .dq-input select + .dq-icon, .dq-input input + .dq-text, .dq-input select + .dq-text {
    padding-left: 0;
    padding-right: 0.5rem;
}

.dq-input:focus-within {
    box-shadow: inset 0 0 0 1px var(--color);
}

.dq-input:focus-within .dq-icon, .dq-input:focus-within .dq-text {
    color: var(--color);
}

.dq-input.-outline {
    background: none;
    box-shadow: inset 0 0 0 1px var(--system);
}

.dq-input.-outline:focus-within {
    box-shadow: inset 0 0 0 1px var(--color);
}



.dq-form>input, .dq-form .dq-input, .dq-form>select {
    margin-bottom: 1rem;
}

.dq-form.-full>input {
    display: block;
    width: 100%;
}
.dq-form.-full .dq-input {
    display: flex;
}

.dq-input.-small, input.-small{
    height: 30px;
}



/* :has not standard for now */
.dq-label:has(+ input:required):after {
    content: "*";
    color: var(--danger);
    font-weight: 800;
}
.dq-label:has(+ .dq-input >input:required):after {
    content: "*";
    color: var(--danger);
    font-weight: 800;
}

.dq-label {
    color: var(--system);
    font-size: 12px;
    letter-spacing: 0.5px;
    margin-bottom: 2px;
}

/* SELECT */
select {
    --color: var(--primary);
    font-family: inherit;
    outline: none;
    padding: 0.75rem;
    box-sizing: border-box;
    border: none;
    border-radius: 0.25rem;
    background: var(--shade);
    /* box-shadow: inset 0px 0 2px var(--shade); */
    font-size: .82rem;
    transition: 0.05s;
    color: var(--white);
    height: 40px;
    min-width: 10px;
    vertical-align: middle;
}

select.-outline {
    background: none;
    box-shadow: inset 0 0 0 1px var(--system);
}
select.-outline:focus, select:focus {
    box-shadow: inset 0 0 0 1px var(--color);
}

.dq-input select:focus {
    box-shadow: none;
}

select option {
    background: var(--black);
    color: var(--grad1);
    font-size: 14px;
}

/* CHECKBOXES & RADIOS */

input[type="checkbox"] {
    width: 20px;
    height: 20px;
    position: relative;
    appearance: none;
    margin: 0;
    background: none;
    box-shadow: inset 0 0 0 1px var(--system);
    display: inline-block;
    transition: 0.2s;
    vertical-align: middle;
    padding: 0;
}

input[type="checkbox"]:checked {
    background: var(--color);
    box-shadow: inset 0 0 0 1px var(--color);
}

input[type="checkbox"]:after {
    content: "✓";
    position: absolute;
    width: 100%;
    line-height: 20px;
    top: 0;
    left: 0;
    text-align: center;
    color: var(--black);
    font-weight: bold;
    transition: 0.2s;
    opacity: 0;
}

input[type="checkbox"]:checked:after {
    opacity: 1;
}




input[type="radio"] {
    width: 20px;
    height: 20px;
    position: relative;
    appearance: none;
    margin: 0;
    background: none;
    box-shadow: inset 0 0 0 1px var(--system);
    display: inline-block;
    border-radius: 100%;
    transition: 0.2s;
    vertical-align: middle;
    padding: 0;
}

input[type="radio"]:checked {
    background: var(--color);
    box-shadow: inset 0 0 0 2px var(--color);
}



input.dq-switch {
    width: 40px;
    height: 20px;
    border-radius: 3rem;
}


input.dq-switch:after {
    content: "";
    width: 12px;
    height: 12px;
    background: var(--system);
    border-radius: 2rem;
    left: 4px;
    top: 4px;
    opacity: 1;
}

input.dq-switch:checked:after {
    left: 24px;
    background: var(--black);
    box-shadow: inset 0 0 0 2px var(--black);
}



/* SLIDER */

.dq-slider {
    --color: var(--primary);
    --color-light: var(--primary-light);
    --color-dark: var(--primary-dark);
    --radius: var(--base-radius);
    -webkit-appearance: none;
    appearance: none;
    width: 100%;
    height: 12px;
    outline: none;
    padding: 0;
	overflow:hidden;
    margin:0;
    border-radius: var(--radius);
}

.dq-slider.-round{
    --radius: 10rem;
}
.dq-slider.-square{
    --radius: 1px;
}


.dq-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 12px;
    height: 12px;
    background: linear-gradient(to left, var(--shine),var(--shine)) var(--color-light);
    border-radius: var(--radius);
	box-shadow: -100vmax 0 0 calc(100vmax - 8px)  var(--color-dark);
}


.dq-slider::-moz-range-thumb {
    width: 12px;
    height: 12px;
    background: linear-gradient(to left, var(--shine),var(--shine)) var(--color-light);
    border-radius: var(--radius);
	box-shadow: -100vmax 0 0 calc(100vmax - 8px)  var(--color-dark);
}

.dq-slider:focus{
    box-shadow: none;
}







/* CHIP */

.dq-chip {
    --color: var(--primary);
    --color-light: var(--primary-light);
    --color-dark: var(--primary-dark);
    color: var(--color-dark);
    display: inline-grid;
    grid-auto-flow: column;
    grid-gap: 0.25rem;
    align-items: center;
    position: relative;
    z-index: 1;
    padding: 0.25rem 0.5rem;
    font-size: 14px;
    font-weight: 600;
    vertical-align: middle;
}

.dq-chip:after {
    content: "";
    background: var(--color-light);
    width: 100%;
    height: 100%;
    position: absolute;
    opacity: 0.25;
    z-index: -1;
    left: 0;
    top: 0;
    border-radius: 50px;
}

.dq-chip .dq-icon {
    font-size: 16px;
}

/* BADGE */

.dq-badge{
    position: relative;
}
.dq-badge:before{
    --color: var(--white);
    content: attr(data-badge);
    position: absolute;
    background: var(--color);
    color: var(--black);
    font-size: 10px;
    height: 18px;
    padding: 0 5px;
    line-height: 18px;
    min-width: 8px;
    text-align: center;
    border-radius: 20px;
    top: -6px;
    right: -6px;
    font-variant: all-petite-caps;
    z-index: 5;
    white-space: nowrap;
    letter-spacing: normal;
}

/* MENUS */

.dq-menu {
    background-color: var(--black);
    padding: 0.5rem 0;
    border-radius: calc(var(--base-radius) * 2);
    box-shadow: 0 0.2rem 0.75rem var(--shadow);
    display: inline-block
}
.dq-menu.-full {
    display: block;
    width: 100%;
}

.dq-menu .dq-item {
    --color: var(--white);
    padding: 0.5rem 2rem 0.5rem 1rem;
    transition: 0.1s;
    border-radius: 0;
    font-size: 14px;
    display: grid;
    grid-auto-flow: column;
    justify-content: start;
    align-items: center;
    grid-gap: 1rem;
    height: 40px;
    color: var(--color);
    user-select: none;
    text-decoration: none;
}

.dq-menu .dq-item:hover {
    background-color: var(--shade);
    cursor: pointer;
}

.dq-menu .dq-item:active {
    background: var(--shadow);
}

.dq-menu .dq-label {
    padding: 0 1rem;
    font-variant: all-petite-caps;
    letter-spacing: 0;
}
.dq-menu.-small .dq-label {
    padding: 0rem 0.75rem;
}

.dq-menu.-small .dq-item {
    padding: 0rem 0.75rem;
    height: 30px;
    grid-gap: 0.5rem;
}

.dq-menu.-small .dq-item .dq-icon {
    font-size: 18px;
}
.dq-menu.-flat{
    border-radius: 0;
    box-shadow: none;
}


/* DROPDOWN */

.dq-dropdown {
    display: inline-grid;
    position: relative;
    vertical-align: middle;
}

.dq-dropdown .dq-menu {
    opacity: 0;
    top: 90%;
    transition: 0.2s;
    visibility: hidden;
    position: absolute;
    z-index: 10;
}


.dq-dropdown:focus .dq-menu, .dq-dropdown:focus-within .dq-menu {
    opacity: 1;
    visibility: visible;
    top: 110%;
}

.dq-dropdown.-end .dq-menu{
    right:0;
}

.dq-dropdown .dq-menu:has(+ *) {
    bottom: 90%;
    top: auto;
}
.dq-dropdown:focus .dq-menu:has(+ *) {
    bottom: 110%;
    top: auto;
}


/* PROGRESS BAR */

.dq-progress {
    --radius: 2px;
    --height: 5px;
    width: 100%;
    height: var(--height);
    background: var(--shade);
    border-radius: var(--radius);
    position: relative;
}

.dq-progressbar {
    width: 0%;
    height: var(--height);
    background: var(--primary);
    border-radius: var(--radius);
    transition: 0.2s;
}

.dq-progress.-thin{
    --height: 3px;
}
.dq-progress.-bold{
    --height: 7px;
}
.dq-progress.-square{
    --radius: 0px;
}
.dq-progress.-round{
    --radius: 10px;
}


/* TITLES */

.dq-title {
    font-size: 20px;
    font-weight: 400;
    --color:var(--white);
    color: var(--color);
}

.dq-title.-h1 {
    font-size: 40px;
    font-weight: 600;
}

.dq-title.-h2 {
    font-size: 34px;
    font-weight: 500;
}

.dq-title.-h3 {
    font-size: 28px;
    font-weight: 400;
}

.dq-title.-h4 {
    font-size: 24px;
    font-weight: 400;
}

/* LINED */


.dq-lined {
    position: relative;
    overflow: hidden;
    z-index: -1;
    display: block;
}

.dq-lined:after {
    content: "";
    border-bottom: 1px solid var(--grad4);
    position: absolute;
    width: 100%;
    height: 50%;
    margin-left: 1rem;
}


/* TOOLTIP */

.dq-tooltip:before{
    content: attr(data-tooltip);
    pointer-events: none;
    position: absolute;
    background: var(--grad1);
    color: var(--black);
    padding: 0.25rem 0.5rem;
    border-radius: 0.25rem;
    left: 0;
    right: 0;
    bottom: calc(-1em - 50%);
    white-space: nowrap;
    opacity: 0;
    visibility: hidden;
    transition: 0.15s;
    display: table;
    box-shadow: 0 0.2rem 0.5rem var(--shade);
    font-family: inherit;
    text-transform: initial;
    font-size: 11px;
    line-height: initial;
    margin: auto;
    font-weight: initial;
    margin-top: 5px;
    z-index: 100;
    transform: scale(0);
    transform-origin: top left;
}
.dq-tooltip {
    position: relative;
}


.dq-tooltip:hover:before {
    opacity: 1;
    visibility: visible;
    transition-delay: 0.75s;
    transform: scale(1);
}


/* TABLE */

.dq-table {
    background: var(--black);
    border-radius: .5rem;
    box-shadow: 0 .2rem .5rem var(--shadow);
    border-collapse: collapse;
    overflow: hidden;
    color: var(--white);
}

.dq-table th, .dq-table td {
    padding: .75rem 1rem;
    border:none;
}

.dq-table td{
    border-top:1px solid var(--grad5);
}

.dq-table tr:hover {
    background: var(--shade);
    border-radius: 1rem;
}




/* SKELETON */
.dq-skeleton {
    height: 1rem;
    background: var(--grad5);
    margin-bottom: 0.5rem;
    border-radius: 2px;
    width: 100%;
    position: relative;
    overflow: hidden;
}
.dq-skeleton.-full{
    height: 100%;
}

.dq-skeleton:nth-last-of-type(1) {
    width: 75%;
}

.dq-skeleton.-icon {
    width: 2rem;
    height: 2rem;
    border-radius: 5rem;
}
.dq-skeleton.-title {
    height: 2rem;
    border-radius: 3px;
}
.dq-skeleton.-w10{
    width: 10rem;
}
span.dq-skeleton {
    display: inline-block;
}

.dq-skeleton.-animated:after {
    content: "";
    position: absolute;
    background-image: linear-gradient(90deg, transparent, var(--black) , transparent);
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    transform: translateX(-100%);
    animation: skeleton 3s infinite;
    opacity: 0.5;
} 

@keyframes skeleton {
    100% { transform: translateX(100%); }
}


/* CARDS */

.dq-card {
    --padding:1rem;
    box-shadow: 0 0.5rem 1rem var(--shadow);
    background: var(--black);
    border-radius: calc(var(--base-radius) * 1.5);
    overflow: hidden;
}


/* CONTENTS */
.dq-head {
    font-size: 20px;
    font-weight: 600;
    padding: var(--padding);
    display: grid;
    grid-gap: 1rem;
    align-items: center;
    grid-auto-flow: column;
    justify-content: start;
}

.dq-content {
    padding: var(--padding);
}

.dq-foot {
    font-size: 12px;
    padding: var(--padding);
}

.dq-card:has(.dq-head) .dq-content {
    padding-top: 0;
}

.dq-card:has(.dq-foot) .dq-content {
    padding-bottom: 0;
}




/* MODAL */

.dq-modal {
    background: var(--black);
    padding: 1rem;
    box-shadow: 0 0.5rem 1rem var(--shadow);
    border-radius: calc(var(--base-radius) * 2);
    position: fixed;
    margin: auto;
    right: 0;
    left: 0;
    top: 0;
    bottom: 0;
    width: fit-content;
    max-width: 40vw;
    height: fit-content;
    max-height: 60vh;
    z-index: 100;
    transition: 0.2s;
    opacity: 0;
    visibility: hidden;
    transform: scale(0.8);
    border:0;
}

.dq-modal.-visible {
    opacity: 1;
    visibility: visible;
    transform: scale(1);
}

.dq-backdrop {
    position: fixed;
    background-color: var(--shadow);
    width: 100%;
    height: 100%;
    z-index: 50;
    top: 0;
    left: 0;
    opacity: 0;
    transition: 0.2s;
    visibility: hidden;
}
.dq-modal.-visible + .dq-backdrop {
    visibility: visible;
    opacity: 1;
}

/* DETAILS */

.dq-details {
    border: none;
    padding: 1rem;
    border-radius: var(--base-radius);
    background: var(--black);
    overflow: hidden;
    width: 100%;
    box-shadow: 0 0.2rem 0.75rem var(--shadow);
}

.dq-details summary {
    padding: 1rem;
    margin: -1rem;
    background: var(--color);
    cursor: pointer;
    --color: var(
    --primary);
    color: var(--black);
}

.dq-details[open] summary {
    margin-bottom: 1rem;
}


/* SPINNER */

.dq-spinner{
    --color: var(--primary);
    width: 20px;
    height: 20px;
    border: 2px solid var(--color);
    border-bottom-color: transparent;
    border-radius: 50%;
    display: inline-block;
    box-sizing: border-box;
    animation: spinner-rotation 1.5s linear infinite;
    vertical-align: -5px;
}

@keyframes spinner-rotation {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}

/* TOAST */

.dq-toastzone {
    position: fixed;
    bottom: 1rem;
    left: 1rem;
    display: grid;
    grid-auto-flow: row;
    grid-gap: .5rem;
    justify-items: start;
    z-index: 100;
}

.dq-toastzone.-end {
    justify-items: end;
    left: auto;
    right: 1rem;
}

.dq-toast {
    --delay: 5s;
    --color: var(--white);
    background-color: var(--color);
    color: var(--black);
    padding: 1rem;
    border-radius: calc(var(--base-radius)* 2);
    box-shadow: 0 0.2rem 0.5rem var(--shadow);
    height: 48px;
    font-size: 14px;
    animation: toast-enter 0.2s forwards;
    display: grid;
    grid-auto-flow: column;
    grid-gap: 0.5rem;
    align-items: center;
    justify-content: start;
}

.dq-toast .dq-icon {
    font-size: 16px;
}

.dq-toast.-hide{
    animation: toast-enter 0.2s forwards,toast-hide 0.2s var(--delay) forwards;
}

@keyframes toast-enter {
    0% {
        opacity: 0;
        visibility: hidden;
        height:0px;
        overflow: hidden;
        padding-top: 0;
        padding-bottom:0;
    }
    100% {
        opacity: 1;
        visibility: visible;
    }
}
@keyframes toast-hide {
    0% {
        opacity: 1;
        visibility: visible;
    }
    100% {
        opacity: 0;
        visibility: hidden;
        height:0px;
        overflow: hidden;
        padding-top: 0;
        padding-bottom:0;
        display: none;
    }
}


/* COLORS */
.-success { 
    --color: var(--success);
    --color-light: var(--success-light);
    --color-dark: var(--success-dark);
}
.-danger { 
    --color: var(--danger);
    --color-light: var(--danger-light);
    --color-dark: var(--danger-dark);
}
.-warning { 
    --color: var(--warning);
    --color-light: var(--warning-light);
    --color-dark: var(--warning-dark);
}
.-primary { 
    --color: var(--primary);
    --color-light: var(--primary-light);
    --color-dark: var(--primary-dark);
}
.-secondary { 
    --color: var(--secondary);
    --color-light: var(--secondary-light);
    --color-dark: var(--secondary-dark);
}
.-dark { 
    --color: var(--dark);
    --color-light: var(--dark-light);
    --color-dark: var(--dark-dark);
}

.-light { 
    --color: var(--light);
    --color-light: var(--light-light);
    --color-dark: var(--light-light);
}


/* UTILS */

.dq-maxl{
    --maxlines: 4;
    --lineheight: inherit;
    -webkit-line-clamp: var(--maxlines);
    -webkit-box-orient: vertical;
    display: -webkit-box;
    /* Compat */
    overflow: hidden;
    max-height: calc(var(--lineheight) * var(--maxlines));
    line-height: var(--lineheight);
}

.dq-hr{
    height: 1px;
    background-color: var(--grad4);
    margin: 0.5rem 0;
}

.dq-variant{
    font-variant: all-petite-caps;
}


/* COMMONS */
.-shade{
    background-color: var(--shade);
}
.-radius {
    border-radius: var(--base-radius);
}
.-center{
    text-align: center;
}
.-left{
    text-align: left;
}
.-right{
    text-align: right;
}



[class*="dq-grid"]{
    --cols:"auto";
    display: grid;
    grid-gap: var(--grid-gap);
    align-items: center;
    grid-template-columns: var(--cols);
}
.dq-grid-2{ --cols: 1fr 1fr;}
.dq-grid-a2{  --cols: auto 1fr;}
.dq-grid-2a{  --cols: 1fr auto;}

.dq-grid-3{ --cols: 1fr 1fr 1fr;}
.dq-grid-a3{ --cols: auto 1fr 1fr;}
.dq-grid-aa3{ --cols: auto auto 1fr;}
.dq-grid-3a{ --cols: 1fr 1fr auto;}
.dq-grid-a3a{ --cols: auto 1fr auto;}
.dq-grid-3aa{ --cols: 1fr auto auto;}

.dq-grid-4{ --cols: 1fr 1fr 1fr 1fr;}
.dq-grid-a4{ --cols: auto 1fr 1fr 1fr;}
.dq-grid-4a{ --cols: 1fr 1fr 1fr auto;}
.dq-grid-a4a{ --cols: auto 1fr 1fr auto;}

.dq-grid-5{ --cols: 1fr 1fr 1fr 1fr 1fr;}
.dq-grid-a5{ --cols: auto 1fr 1fr 1fr 1fr;}
.dq-grid-5a{ --cols: 1fr 1fr 1fr 1fr auto;}
.dq-grid-a5a{ --cols: auto 1fr 1fr 1fr auto;}


.dq-gap-0{ grid-gap: 0rem;}
.dq-gap-05{ grid-gap: 0.5rem;}
.dq-gap-1{ grid-gap: 1rem;}
.dq-gap-2{ grid-gap: 2rem;}

.dq-grid-flow {
    grid-auto-flow: column;
}

[class*="dq-grid"].-rows {
    grid-template-columns: initial;
    grid-template-rows: var(--cols);
}


[class*="dq-grid"].-align-start { align-items: start; }
[class*="dq-grid"].-align-center { align-items: center; }
[class*="dq-grid"].-align-end { align-items: end; }


/* Breakpoints */

@media (max-width: 480px) {
    [class*="dq-grid"].-wrap-s {
        --cols: 1fr !important;
    }
}


@media (max-width: 720px) {
    [class*="dq-grid"].-wrap-m, [class*="dq-grid"].-wrap {
        --cols: 1fr !important;
    }
}


@media (max-width: 1024px) {
    [class*="dq-grid"].-wrap-l {
        --cols: 1fr !important;
    }
}





*{
    box-sizing: border-box;
}




/* Margin */

.m-0 {margin: 0 !important; }
.m-05 {margin: 0.5rem !important; }
.m-1 {margin: 1rem !important; }
.m-2 {margin: 2rem !important; }
.m-3 {margin: 3rem !important; }

.mt-05, .my-05{ margin-top: 0.5rem !important; }
.mt-1, .my-1{ margin-top: 1rem !important; }
.mt-2, .my-2{ margin-top: 2rem !important; }
.mt-3, .my-3{ margin-top: 3rem !important; }

.mb-05, .my-05{ margin-bottom: 0.5rem !important; }
.mb-1, .my-1{ margin-bottom: 1rem !important; }
.mb-2, .my-2{ margin-bottom: 2rem !important; }
.mb-3, .my-3{ margin-bottom: 3rem !important; }

.ml-05, .mx-05{ margin-left: 0.5rem !important; }
.ml-1, .mx-1{ margin-left: 1rem !important; }
.ml-2, .mx-2{ margin-left: 2rem !important; }
.ml-3, .mx-3{ margin-left: 3rem !important; }

.mr-05, .mx-05{ margin-right: 0.5rem !important; }
.mr-1, .mx-1{ margin-right: 1rem !important; }
.mr-2, .mx-2{ margin-right: 2rem !important; }
.mr-3, .mx-3{ margin-right: 3rem !important; }

.mx-a{ margin-left: auto !important; margin-right: auto !important; }

/* Padding */

.p-0 {padding: 0 !important; }
.p-05 {padding: 0.5rem !important; }
.p-1 {padding: 1rem !important; }
.p-2 {padding: 2rem !important; }
.p-3 {padding: 3rem !important; }

.pt-05, .py-05{ padding-top: 0.5rem !important; }
.pt-1, .py-1{ padding-top: 1rem !important; }
.pt-2, .py-2{ padding-top: 2rem !important; }
.pt-3, .py-3{ padding-top: 3rem !important; }

.pb-05, .py-05{ padding-bottom: 0.5rem !important; }
.pb-1, .py-1{ padding-bottom: 1rem !important; }
.pb-2, .py-2{ padding-bottom: 2rem !important; }
.pb-3, .py-3{ padding-bottom: 3rem !important; }

.pl-05, .px-05{ padding-left: 0.5rem !important; }
.pl-1, .px-1{ padding-left: 1rem !important; }
.pl-2, .px-2{ padding-left: 2rem !important; }
.pl-3, .px-3{ padding-left: 3rem !important; }

.pr-05, .px-05{ padding-right: 0.5rem !important; }
.pr-1, .px-1{ padding-right: 1rem !important; }
.pr-2, .px-2{ padding-right: 2rem !important; }
.pr-3, .px-3{ padding-right: 3rem !important; }


/* BORDER */

.b-0{ border:0 !important; }
.b-1{ border: 1px solid var(--grad4) !important; }

.bt-1, .by-1{ border-top: 1px solid var(--grad4) !important; }
.bb-1, .by-1{ border-bottom: 1px solid var(--grad4) !important; }

.bl-1, .bx-1{ border-left: 1px solid var(--grad4) !important; }
.br-1, .bx-1{ border-right: 1px solid var(--grad4) !important; }



/* 
@media (prefers-color-scheme: dark) {
    :root {
        --black: hsl(0, 0%, 14%);
        --white: #ffffff;
        --back: hsl(0, 0%, 7%);
        --grad1: hsl(0deg 0% 80%);
        --grad2: hsl(0deg 0% 60%);
        --grad3: hsl(0deg 0% 40%);
        --grad4: hsl(0deg 0% 20%);
        --grad5: hsl(0deg 0% 10%);
        --shade: rgba(0,0,0,0.40);
        --shadow: rgba(0,0,0,0.45);

        --dark: hsl(0deg 0% 80%);
        --dark-light: hsl(0deg 0% 85%);
        --dark-dark: hsl(0deg 0% 75%);
    }
}
body.dq-night{
    --black: hsl(0, 0%, 14%);
    --white: #ffffff;
    --back: hsl(0, 0%, 7%);
    --grad1: hsl(0deg 0% 80%);
    --grad2: hsl(0deg 0% 60%);
    --grad3: hsl(0deg 0% 40%);
    --grad4: hsl(0deg 0% 20%);
    --grad5: hsl(0deg 0% 10%);
    --shade: rgba(0,0,0,0.40);
    --shadow: rgba(0,0,0,0.45);

    --dark: hsl(0deg 0% 90%);
    --dark-light: hsl(0deg 0% 95%);
    --dark-dark: hsl(0deg 0% 85%);
} */
