*, :before, :after {
    --tw-border-spacing-x: 0;
    --tw-border-spacing-y: 0;
    --tw-translate-x: 0;
    --tw-translate-y: 0;
    --tw-rotate: 0;
    --tw-skew-x: 0;
    --tw-skew-y: 0;
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    --tw-pan-x:;
    --tw-pan-y:;
    --tw-pinch-zoom:;
    --tw-scroll-snap-strictness: proximity;
    --tw-gradient-from-position:;
    --tw-gradient-via-position:;
    --tw-gradient-to-position:;
    --tw-ordinal:;
    --tw-slashed-zero:;
    --tw-numeric-figure:;
    --tw-numeric-spacing:;
    --tw-numeric-fraction:;
    --tw-ring-inset:;
    --tw-ring-offset-width: 0px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: rgb(59 130 246 / .5);
    --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    --tw-blur:;
    --tw-brightness:;
    --tw-contrast:;
    --tw-grayscale:;
    --tw-hue-rotate:;
    --tw-invert:;
    --tw-saturate:;
    --tw-sepia:;
    --tw-drop-shadow:;
    --tw-backdrop-blur:;
    --tw-backdrop-brightness:;
    --tw-backdrop-contrast:;
    --tw-backdrop-grayscale:;
    --tw-backdrop-hue-rotate:;
    --tw-backdrop-invert:;
    --tw-backdrop-opacity:;
    --tw-backdrop-saturate:;
    --tw-backdrop-sepia:;
    --tw-contain-size:;
    --tw-contain-layout:;
    --tw-contain-paint:;
    --tw-contain-style:;
}

::backdrop {
    --tw-border-spacing-x: 0;
    --tw-border-spacing-y: 0;
    --tw-translate-x: 0;
    --tw-translate-y: 0;
    --tw-rotate: 0;
    --tw-skew-x: 0;
    --tw-skew-y: 0;
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    --tw-pan-x:;
    --tw-pan-y:;
    --tw-pinch-zoom:;
    --tw-scroll-snap-strictness: proximity;
    --tw-gradient-from-position:;
    --tw-gradient-via-position:;
    --tw-gradient-to-position:;
    --tw-ordinal:;
    --tw-slashed-zero:;
    --tw-numeric-figure:;
    --tw-numeric-spacing:;
    --tw-numeric-fraction:;
    --tw-ring-inset:;
    --tw-ring-offset-width: 0px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: rgb(59 130 246 / .5);
    --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    --tw-blur:;
    --tw-brightness:;
    --tw-contrast:;
    --tw-grayscale:;
    --tw-hue-rotate:;
    --tw-invert:;
    --tw-saturate:;
    --tw-sepia:;
    --tw-drop-shadow:;
    --tw-backdrop-blur:;
    --tw-backdrop-brightness:;
    --tw-backdrop-contrast:;
    --tw-backdrop-grayscale:;
    --tw-backdrop-hue-rotate:;
    --tw-backdrop-invert:;
    --tw-backdrop-opacity:;
    --tw-backdrop-saturate:;
    --tw-backdrop-sepia:;
    --tw-contain-size:;
    --tw-contain-layout:;
    --tw-contain-paint:;
    --tw-contain-style:;
}

*, :before, :after {
    box-sizing: border-box;
    border-width: 0;
    border-style: solid;
    border-color: #e5e7eb;
}

:before, :after {
    --tw-content: "";
}

html, :host {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    -moz-tab-size: 4;
    -o-tab-size: 4;
    tab-size: 4;
    font-family: ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";
    font-feature-settings: normal;
    font-variation-settings: normal;
    -webkit-tap-highlight-color: transparent;
}

body {
    margin: 0;
    line-height: inherit;
}

hr {
    height: 0;
    color: inherit;
    border-top-width: 1px;
}

abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
}

h1, h2, h3, h4, h5, h6 {
    font-size: inherit;
    font-weight: inherit;
}

a {
    color: inherit;
    text-decoration: inherit;
}

b, strong {
    font-weight: bolder;
}

code, kbd, samp, pre {
    font-family: ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;
    font-feature-settings: normal;
    font-variation-settings: normal;
    font-size: 1em;
}

small {
    font-size: 80%;
}

sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
}

sub {
    bottom: -.25em;
}

sup {
    top: -.5em;
}

table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
}

button, input, optgroup, select, textarea {
    font-family: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    font-size: 100%;
    font-weight: inherit;
    line-height: inherit;
    letter-spacing: inherit;
    color: inherit;
    margin: 0;
    padding: 0;
}

button, select {
    text-transform: none;
}

button, input:where([type=button]), input:where([type=reset]), input:where([type=submit]) {
    -webkit-appearance: button;
    background-color: transparent;
    background-image: none;
}

:-moz-focusring {
    outline: auto;
}

:-moz-ui-invalid {
    box-shadow: none;
}

progress {
    vertical-align: baseline;
}

::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
    height: auto;
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px;
}

::-webkit-search-decoration {
    -webkit-appearance: none;
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit;
}

summary {
    display: list-item;
}

blockquote, dl, dd, h1, h2, h3, h4, h5, h6, hr, figure, p, pre {
    margin: 0;
}

fieldset {
    margin: 0;
    padding: 0;
}

legend {
    padding: 0;
}

ol, ul, menu {
    list-style: none;
    margin: 0;
    padding: 0;
}

dialog {
    padding: 0;
}

textarea {
    resize: vertical;
}

    input::-moz-placeholder, textarea::-moz-placeholder {
        opacity: 1;
        color: #9ca3af;
    }

    input::placeholder, textarea::placeholder {
        opacity: 1;
        color: #9ca3af;
    }

button, [role=button] {
    cursor: pointer;
}

:disabled {
    cursor: default;
}

img, svg, video, canvas, audio, iframe, embed, object {
    display: block;
    vertical-align: middle;
}

img, video {
    max-width: 100%;
    height: auto;
}

[hidden]:where(:not([hidden=until-found])) {
    display: none;
}

:root {
    --p: 70.9115% .18488 48.973383;
    --b2: 93% 0 0;
    --b3: 86% 0 0;
    --bc: 20% 0 0;
    --sc: 15.7924% .027065 55.898183;
    --ac: 14.0113% .038673 46.06908;
    --nc: 89.7494% .020559 52.917228;
    --inc: 16.5969% .022127 62.264436;
    --suc: 17.5838% .018031 74.337905;
    --wac: 14.4624% .035602 49.19346;
    --erc: 13.601% .041153 40.87676;
    --rounded-box: 1rem;
    --rounded-btn: .5rem;
    --rounded-badge: 1.9rem;
    --animation-btn: .25s;
    --animation-input: .2s;
    --btn-focus-scale: .95;
    --border-btn: 1px;
    --tab-border: 1px;
    --tab-radius: .5rem;
    --pc: 100% 0 0;
    --s: 78.9622% .135324 55.898183;
    --a: 70.0565% .193367 46.06908;
    --n: 48.747% .102793 52.917228;
    --b1: 100% 0 0;
    --in: 82.9843% .110636 62.264436;
    --su: 87.919% .090154 74.337905;
    --wa: 72.3119% .178009 49.19346;
    --er: 68.0048% .205763 40.87676;
    --gpe-orange: #F97316;           /* naranja principal */
    --gpe-orange-50: #FFF3E9;        /* fondo claro */
    --gpe-orange-200: #FFCFAD;       /* borde claro */
    --gpe-text: #0f172a;             /* texto */
    --gpe-muted: #64748b;            /* texto secundario */
}

.container {
    width: 100%;
}

@media (min-width: 640px) {
    .container {
        max-width: 640px;
    }
}

@media (min-width: 768px) {
    .container {
        max-width: 768px;
    }
}

@media (min-width: 1024px) {
    .container {
        max-width: 1024px;
    }
}

@media (min-width: 1280px) {
    .container {
        max-width: 1280px;
    }
}

@media (min-width: 1536px) {
    .container {
        max-width: 1536px;
    }
}

.prose {
    color: var(--tw-prose-body);
    max-width: 65ch;
}

    .prose :where(p):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 1.25em;
        margin-bottom: 1.25em;
    }

    .prose :where([class~=lead]):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: var(--tw-prose-lead);
        font-size: 1.25em;
        line-height: 1.6;
        margin-top: 1.2em;
        margin-bottom: 1.2em;
    }

    .prose :where(a):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: var(--tw-prose-links);
        text-decoration: underline;
        font-weight: 500;
    }

    .prose :where(strong):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: var(--tw-prose-bold);
        font-weight: 600;
    }

    .prose :where(a strong):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: inherit;
    }

    .prose :where(blockquote strong):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: inherit;
    }

    .prose :where(thead th strong):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: inherit;
    }

    .prose :where(ol):not(:where([class~=not-prose],[class~=not-prose] *)) {
        list-style-type: decimal;
        margin-top: 1.25em;
        margin-bottom: 1.25em;
        padding-inline-start: 1.625em;
    }

    .prose :where(ol[type=A]):not(:where([class~=not-prose],[class~=not-prose] *)) {
        list-style-type: upper-alpha;
    }

    .prose :where(ol[type=a]):not(:where([class~=not-prose],[class~=not-prose] *)) {
        list-style-type: lower-alpha;
    }

    .prose :where(ol[type=A s]):not(:where([class~=not-prose],[class~=not-prose] *)) {
        list-style-type: upper-alpha;
    }

    .prose :where(ol[type=a s]):not(:where([class~=not-prose],[class~=not-prose] *)) {
        list-style-type: lower-alpha;
    }

    .prose :where(ol[type=I]):not(:where([class~=not-prose],[class~=not-prose] *)) {
        list-style-type: upper-roman;
    }

    .prose :where(ol[type=i]):not(:where([class~=not-prose],[class~=not-prose] *)) {
        list-style-type: lower-roman;
    }

    .prose :where(ol[type=I s]):not(:where([class~=not-prose],[class~=not-prose] *)) {
        list-style-type: upper-roman;
    }

    .prose :where(ol[type=i s]):not(:where([class~=not-prose],[class~=not-prose] *)) {
        list-style-type: lower-roman;
    }

    .prose :where(ol[type="1"]):not(:where([class~=not-prose],[class~=not-prose] *)) {
        list-style-type: decimal;
    }

    .prose :where(ul):not(:where([class~=not-prose],[class~=not-prose] *)) {
        list-style-type: disc;
        margin-top: 1.25em;
        margin-bottom: 1.25em;
        padding-inline-start: 1.625em;
    }

    .prose :where(ol>li):not(:where([class~=not-prose],[class~=not-prose] *))::marker {
        font-weight: 400;
        color: var(--tw-prose-counters);
    }

    .prose :where(ul>li):not(:where([class~=not-prose],[class~=not-prose] *))::marker {
        color: var(--tw-prose-bullets);
    }

    .prose :where(dt):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: var(--tw-prose-headings);
        font-weight: 600;
        margin-top: 1.25em;
    }

    .prose :where(hr):not(:where([class~=not-prose],[class~=not-prose] *)) {
        border-color: var(--tw-prose-hr);
        border-top-width: 1px;
        margin-top: 3em;
        margin-bottom: 3em;
    }

    .prose :where(blockquote):not(:where([class~=not-prose],[class~=not-prose] *)) {
        font-weight: 500;
        font-style: italic;
        color: var(--tw-prose-quotes);
        border-inline-start-width: .25rem;
        border-inline-start-color: var(--tw-prose-quote-borders);
        quotes: "“""”""‘""’";
        margin-top: 1.6em;
        margin-bottom: 1.6em;
        padding-inline-start: 1em;
    }

    .prose :where(blockquote p:first-of-type):not(:where([class~=not-prose],[class~=not-prose] *)):before {
        content: open-quote;
    }

    .prose :where(blockquote p:last-of-type):not(:where([class~=not-prose],[class~=not-prose] *)):after {
        content: close-quote;
    }

    .prose :where(h1):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: var(--tw-prose-headings);
        font-weight: 800;
        font-size: 2.25em;
        margin-top: 0;
        margin-bottom: .8888889em;
        line-height: 1.1111111;
    }

    .prose :where(h1 strong):not(:where([class~=not-prose],[class~=not-prose] *)) {
        font-weight: 900;
        color: inherit;
    }

    .prose :where(h2):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: var(--tw-prose-headings);
        font-weight: 700;
        font-size: 1.5em;
        margin-top: 2em;
        margin-bottom: 1em;
        line-height: 1.3333333;
    }

    .prose :where(h2 strong):not(:where([class~=not-prose],[class~=not-prose] *)) {
        font-weight: 800;
        color: inherit;
    }

    .prose :where(h3):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: var(--tw-prose-headings);
        font-weight: 600;
        font-size: 1.25em;
        margin-top: 1.6em;
        margin-bottom: .6em;
        line-height: 1.6;
    }

    .prose :where(h3 strong):not(:where([class~=not-prose],[class~=not-prose] *)) {
        font-weight: 700;
        color: inherit;
    }

    .prose :where(h4):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: var(--tw-prose-headings);
        font-weight: 600;
        margin-top: 1.5em;
        margin-bottom: .5em;
        line-height: 1.5;
    }

    .prose :where(h4 strong):not(:where([class~=not-prose],[class~=not-prose] *)) {
        font-weight: 700;
        color: inherit;
    }

    .prose :where(img):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 2em;
        margin-bottom: 2em;
    }

    .prose :where(picture):not(:where([class~=not-prose],[class~=not-prose] *)) {
        display: block;
        margin-top: 2em;
        margin-bottom: 2em;
    }

    .prose :where(video):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 2em;
        margin-bottom: 2em;
    }

    .prose :where(kbd):not(:where([class~=not-prose],[class~=not-prose] *)) {
        font-weight: 500;
        font-family: inherit;
        color: var(--tw-prose-kbd);
        box-shadow: 0 0 0 1px rgb(var(--tw-prose-kbd-shadows) / 10%),0 3px rgb(var(--tw-prose-kbd-shadows) / 10%);
        font-size: .875em;
        border-radius: .3125rem;
        padding-top: .1875em;
        padding-inline-end: .375em;
        padding-bottom: .1875em;
        padding-inline-start: .375em;
    }

    .prose :where(code):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: var(--tw-prose-code);
        font-weight: 600;
        font-size: .875em;
    }

        .prose :where(code):not(:where([class~=not-prose],[class~=not-prose] *)):before {
            content: "`";
        }

        .prose :where(code):not(:where([class~=not-prose],[class~=not-prose] *)):after {
            content: "`";
        }

    .prose :where(a code):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: inherit;
    }

    .prose :where(h1 code):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: inherit;
    }

    .prose :where(h2 code):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: inherit;
        font-size: .875em;
    }

    .prose :where(h3 code):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: inherit;
        font-size: .9em;
    }

    .prose :where(h4 code):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: inherit;
    }

    .prose :where(blockquote code):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: inherit;
    }

    .prose :where(thead th code):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: inherit;
    }

    .prose :where(pre):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: var(--tw-prose-pre-code);
        background-color: var(--tw-prose-pre-bg);
        overflow-x: auto;
        font-weight: 400;
        font-size: .875em;
        line-height: 1.7142857;
        margin-top: 1.7142857em;
        margin-bottom: 1.7142857em;
        border-radius: .375rem;
        padding-top: .8571429em;
        padding-inline-end: 1.1428571em;
        padding-bottom: .8571429em;
        padding-inline-start: 1.1428571em;
    }

    .prose :where(pre code):not(:where([class~=not-prose],[class~=not-prose] *)) {
        background-color: transparent;
        border-width: 0;
        border-radius: 0;
        padding: 0;
        font-weight: inherit;
        color: inherit;
        font-size: inherit;
        font-family: inherit;
        line-height: inherit;
    }

        .prose :where(pre code):not(:where([class~=not-prose],[class~=not-prose] *)):before {
            content: none;
        }

        .prose :where(pre code):not(:where([class~=not-prose],[class~=not-prose] *)):after {
            content: none;
        }

    .prose :where(table):not(:where([class~=not-prose],[class~=not-prose] *)) {
        width: 100%;
        table-layout: auto;
        margin-top: 2em;
        margin-bottom: 2em;
        font-size: .875em;
        line-height: 1.7142857;
    }

    .prose :where(thead):not(:where([class~=not-prose],[class~=not-prose] *)) {
        border-bottom-width: 1px;
        border-bottom-color: var(--tw-prose-th-borders);
    }

    .prose :where(thead th):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: var(--tw-prose-headings);
        font-weight: 600;
        vertical-align: bottom;
        padding-inline-end: .5714286em;
        padding-bottom: .5714286em;
        padding-inline-start: .5714286em;
    }

    .prose :where(tbody tr):not(:where([class~=not-prose],[class~=not-prose] *)) {
        border-bottom-width: 1px;
        border-bottom-color: var(--tw-prose-td-borders);
    }

    .prose :where(tbody tr:last-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        border-bottom-width: 0;
    }

    .prose :where(tbody td):not(:where([class~=not-prose],[class~=not-prose] *)) {
        vertical-align: baseline;
    }

    .prose :where(tfoot):not(:where([class~=not-prose],[class~=not-prose] *)) {
        border-top-width: 1px;
        border-top-color: var(--tw-prose-th-borders);
    }

    .prose :where(tfoot td):not(:where([class~=not-prose],[class~=not-prose] *)) {
        vertical-align: top;
    }

    .prose :where(th,td):not(:where([class~=not-prose],[class~=not-prose] *)) {
        text-align: start;
    }

    .prose :where(figure>*):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 0;
        margin-bottom: 0;
    }

    .prose :where(figcaption):not(:where([class~=not-prose],[class~=not-prose] *)) {
        color: var(--tw-prose-captions);
        font-size: .875em;
        line-height: 1.4285714;
        margin-top: .8571429em;
    }

.prose {
    --tw-prose-body: #374151;
    --tw-prose-headings: #111827;
    --tw-prose-lead: #4b5563;
    --tw-prose-links: #111827;
    --tw-prose-bold: #111827;
    --tw-prose-counters: #6b7280;
    --tw-prose-bullets: #d1d5db;
    --tw-prose-hr: #e5e7eb;
    --tw-prose-quotes: #111827;
    --tw-prose-quote-borders: #e5e7eb;
    --tw-prose-captions: #6b7280;
    --tw-prose-kbd: #111827;
    --tw-prose-kbd-shadows: 17 24 39;
    --tw-prose-code: #111827;
    --tw-prose-pre-code: #e5e7eb;
    --tw-prose-pre-bg: #1f2937;
    --tw-prose-th-borders: #d1d5db;
    --tw-prose-td-borders: #e5e7eb;
    --tw-prose-invert-body: #d1d5db;
    --tw-prose-invert-headings: #fff;
    --tw-prose-invert-lead: #9ca3af;
    --tw-prose-invert-links: #fff;
    --tw-prose-invert-bold: #fff;
    --tw-prose-invert-counters: #9ca3af;
    --tw-prose-invert-bullets: #4b5563;
    --tw-prose-invert-hr: #374151;
    --tw-prose-invert-quotes: #f3f4f6;
    --tw-prose-invert-quote-borders: #374151;
    --tw-prose-invert-captions: #9ca3af;
    --tw-prose-invert-kbd: #fff;
    --tw-prose-invert-kbd-shadows: 255 255 255;
    --tw-prose-invert-code: #fff;
    --tw-prose-invert-pre-code: #d1d5db;
    --tw-prose-invert-pre-bg: rgb(0 0 0 / 50%);
    --tw-prose-invert-th-borders: #4b5563;
    --tw-prose-invert-td-borders: #374151;
    font-size: 1rem;
    line-height: 1.75;
}

    .prose :where(picture>img):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 0;
        margin-bottom: 0;
    }

    .prose :where(li):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: .5em;
        margin-bottom: .5em;
    }

    .prose :where(ol>li):not(:where([class~=not-prose],[class~=not-prose] *)) {
        padding-inline-start: .375em;
    }

    .prose :where(ul>li):not(:where([class~=not-prose],[class~=not-prose] *)) {
        padding-inline-start: .375em;
    }

    .prose :where(.prose>ul>li p):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: .75em;
        margin-bottom: .75em;
    }

    .prose :where(.prose>ul>li>p:first-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 1.25em;
    }

    .prose :where(.prose>ul>li>p:last-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-bottom: 1.25em;
    }

    .prose :where(.prose>ol>li>p:first-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 1.25em;
    }

    .prose :where(.prose>ol>li>p:last-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-bottom: 1.25em;
    }

    .prose :where(ul ul,ul ol,ol ul,ol ol):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: .75em;
        margin-bottom: .75em;
    }

    .prose :where(dl):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 1.25em;
        margin-bottom: 1.25em;
    }

    .prose :where(dd):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: .5em;
        padding-inline-start: 1.625em;
    }

    .prose :where(hr+*):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 0;
    }

    .prose :where(h2+*):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 0;
    }

    .prose :where(h3+*):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 0;
    }

    .prose :where(h4+*):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 0;
    }

    .prose :where(thead th:first-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        padding-inline-start: 0;
    }

    .prose :where(thead th:last-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        padding-inline-end: 0;
    }

    .prose :where(tbody td,tfoot td):not(:where([class~=not-prose],[class~=not-prose] *)) {
        padding-top: .5714286em;
        padding-inline-end: .5714286em;
        padding-bottom: .5714286em;
        padding-inline-start: .5714286em;
    }

    .prose :where(tbody td:first-child,tfoot td:first-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        padding-inline-start: 0;
    }

    .prose :where(tbody td:last-child,tfoot td:last-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        padding-inline-end: 0;
    }

    .prose :where(figure):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 2em;
        margin-bottom: 2em;
    }

    .prose :where(.prose>:first-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 0;
    }

    .prose :where(.prose>:last-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-bottom: 0;
    }

.prose-lg {
    font-size: 1.125rem;
    line-height: 1.7777778;
}

    .prose-lg :where(p):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 1.3333333em;
        margin-bottom: 1.3333333em;
    }

    .prose-lg :where([class~=lead]):not(:where([class~=not-prose],[class~=not-prose] *)) {
        font-size: 1.2222222em;
        line-height: 1.4545455;
        margin-top: 1.0909091em;
        margin-bottom: 1.0909091em;
    }

    .prose-lg :where(blockquote):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 1.6666667em;
        margin-bottom: 1.6666667em;
        padding-inline-start: 1em;
    }

    .prose-lg :where(h1):not(:where([class~=not-prose],[class~=not-prose] *)) {
        font-size: 2.6666667em;
        margin-top: 0;
        margin-bottom: .8333333em;
        line-height: 1;
    }

    .prose-lg :where(h2):not(:where([class~=not-prose],[class~=not-prose] *)) {
        font-size: 1.6666667em;
        margin-top: 1.8666667em;
        margin-bottom: 1.0666667em;
        line-height: 1.3333333;
    }

    .prose-lg :where(h3):not(:where([class~=not-prose],[class~=not-prose] *)) {
        font-size: 1.3333333em;
        margin-top: 1.6666667em;
        margin-bottom: .6666667em;
        line-height: 1.5;
    }

    .prose-lg :where(h4):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 1.7777778em;
        margin-bottom: .4444444em;
        line-height: 1.5555556;
    }

    .prose-lg :where(img):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 1.7777778em;
        margin-bottom: 1.7777778em;
    }

    .prose-lg :where(picture):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 1.7777778em;
        margin-bottom: 1.7777778em;
    }

    .prose-lg :where(picture>img):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 0;
        margin-bottom: 0;
    }

    .prose-lg :where(video):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 1.7777778em;
        margin-bottom: 1.7777778em;
    }

    .prose-lg :where(kbd):not(:where([class~=not-prose],[class~=not-prose] *)) {
        font-size: .8888889em;
        border-radius: .3125rem;
        padding-top: .2222222em;
        padding-inline-end: .4444444em;
        padding-bottom: .2222222em;
        padding-inline-start: .4444444em;
    }

    .prose-lg :where(code):not(:where([class~=not-prose],[class~=not-prose] *)) {
        font-size: .8888889em;
    }

    .prose-lg :where(h2 code):not(:where([class~=not-prose],[class~=not-prose] *)) {
        font-size: .8666667em;
    }

    .prose-lg :where(h3 code):not(:where([class~=not-prose],[class~=not-prose] *)) {
        font-size: .875em;
    }

    .prose-lg :where(pre):not(:where([class~=not-prose],[class~=not-prose] *)) {
        font-size: .8888889em;
        line-height: 1.75;
        margin-top: 2em;
        margin-bottom: 2em;
        border-radius: .375rem;
        padding-top: 1em;
        padding-inline-end: 1.5em;
        padding-bottom: 1em;
        padding-inline-start: 1.5em;
    }

    .prose-lg :where(ol):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 1.3333333em;
        margin-bottom: 1.3333333em;
        padding-inline-start: 1.5555556em;
    }

    .prose-lg :where(ul):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 1.3333333em;
        margin-bottom: 1.3333333em;
        padding-inline-start: 1.5555556em;
    }

    .prose-lg :where(li):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: .6666667em;
        margin-bottom: .6666667em;
    }

    .prose-lg :where(ol>li):not(:where([class~=not-prose],[class~=not-prose] *)) {
        padding-inline-start: .4444444em;
    }

    .prose-lg :where(ul>li):not(:where([class~=not-prose],[class~=not-prose] *)) {
        padding-inline-start: .4444444em;
    }

    .prose-lg :where(.prose-lg>ul>li p):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: .8888889em;
        margin-bottom: .8888889em;
    }

    .prose-lg :where(.prose-lg>ul>li>p:first-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 1.3333333em;
    }

    .prose-lg :where(.prose-lg>ul>li>p:last-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-bottom: 1.3333333em;
    }

    .prose-lg :where(.prose-lg>ol>li>p:first-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 1.3333333em;
    }

    .prose-lg :where(.prose-lg>ol>li>p:last-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-bottom: 1.3333333em;
    }

    .prose-lg :where(ul ul,ul ol,ol ul,ol ol):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: .8888889em;
        margin-bottom: .8888889em;
    }

    .prose-lg :where(dl):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 1.3333333em;
        margin-bottom: 1.3333333em;
    }

    .prose-lg :where(dt):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 1.3333333em;
    }

    .prose-lg :where(dd):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: .6666667em;
        padding-inline-start: 1.5555556em;
    }

    .prose-lg :where(hr):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 3.1111111em;
        margin-bottom: 3.1111111em;
    }

    .prose-lg :where(hr+*):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 0;
    }

    .prose-lg :where(h2+*):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 0;
    }

    .prose-lg :where(h3+*):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 0;
    }

    .prose-lg :where(h4+*):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 0;
    }

    .prose-lg :where(table):not(:where([class~=not-prose],[class~=not-prose] *)) {
        font-size: .8888889em;
        line-height: 1.5;
    }

    .prose-lg :where(thead th):not(:where([class~=not-prose],[class~=not-prose] *)) {
        padding-inline-end: .75em;
        padding-bottom: .75em;
        padding-inline-start: .75em;
    }

    .prose-lg :where(thead th:first-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        padding-inline-start: 0;
    }

    .prose-lg :where(thead th:last-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        padding-inline-end: 0;
    }

    .prose-lg :where(tbody td,tfoot td):not(:where([class~=not-prose],[class~=not-prose] *)) {
        padding-top: .75em;
        padding-inline-end: .75em;
        padding-bottom: .75em;
        padding-inline-start: .75em;
    }

    .prose-lg :where(tbody td:first-child,tfoot td:first-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        padding-inline-start: 0;
    }

    .prose-lg :where(tbody td:last-child,tfoot td:last-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        padding-inline-end: 0;
    }

    .prose-lg :where(figure):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 1.7777778em;
        margin-bottom: 1.7777778em;
    }

    .prose-lg :where(figure>*):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 0;
        margin-bottom: 0;
    }

    .prose-lg :where(figcaption):not(:where([class~=not-prose],[class~=not-prose] *)) {
        font-size: .8888889em;
        line-height: 1.5;
        margin-top: 1em;
    }

    .prose-lg :where(.prose-lg>:first-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-top: 0;
    }

    .prose-lg :where(.prose-lg>:last-child):not(:where([class~=not-prose],[class~=not-prose] *)) {
        margin-bottom: 0;
    }

.alert {
    display: grid;
    width: 100%;
    grid-auto-flow: row;
    align-content: flex-start;
    align-items: center;
    justify-items: center;
    gap: 1rem;
    text-align: center;
    border-radius: var(--rounded-box, 1rem);
    border-width: 1px;
    --tw-border-opacity: 1;
    border-color: var(--fallback-b2,oklch(var(--b2)/var(--tw-border-opacity)));
    padding: 1rem;
    --tw-text-opacity: 1;
    color: var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity)));
    --alert-bg: var(--fallback-b2,oklch(var(--b2)/1));
    --alert-bg-mix: var(--fallback-b1,oklch(var(--b1)/1));
    background-color: var(--alert-bg);
}

@media (min-width: 640px) {
    .alert {
        grid-auto-flow: column;
        grid-template-columns: auto minmax(auto,1fr);
        justify-items: start;
        text-align: start;
    }
}

.avatar {
    position: relative;
    display: inline-flex;
}

    .avatar > div {
        display: block;
        aspect-ratio: 1 / 1;
        overflow: hidden;
    }

    .avatar img {
        height: 100%;
        width: 100%;
        -o-object-fit: cover;
        object-fit: cover;
    }

    .avatar.placeholder > div {
        display: flex;
        align-items: center;
        justify-content: center;
    }

.breadcrumbs {
    max-width: 100%;
    overflow-x: auto;
    padding-top: .5rem;
    padding-bottom: .5rem;
}

    .breadcrumbs > ul, .breadcrumbs > ol {
        display: flex;
        align-items: center;
        white-space: nowrap;
        min-height: -moz-min-content;
        min-height: min-content;
    }

        .breadcrumbs > ul > li, .breadcrumbs > ol > li {
            display: flex;
            align-items: center;
        }

            .breadcrumbs > ul > li > a, .breadcrumbs > ol > li > a {
                display: flex;
                cursor: pointer;
                align-items: center;
            }

@media (hover:hover) {
    .breadcrumbs > ul > li > a:hover, .breadcrumbs > ol > li > a:hover {
        text-decoration-line: underline;
    }

    .label a:hover {
        --tw-text-opacity: 1;
        color: var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity)));
    }

    .menu li > *:not(ul,.menu-title,details,.btn):active, .menu li > *:not(ul,.menu-title,details,.btn).active, .menu li > details > summary:active {
        --tw-bg-opacity: 1;
        background-color: var(--fallback-n,oklch(var(--n)/var(--tw-bg-opacity)));
        --tw-text-opacity: 1;
        color: var(--fallback-nc,oklch(var(--nc)/var(--tw-text-opacity)));
    }

    .table tr.hover:hover, .table tr.hover:nth-child(2n):hover {
        --tw-bg-opacity: 1;
        background-color: var(--fallback-b2,oklch(var(--b2)/var(--tw-bg-opacity)));
    }

    .table-zebra tr.hover:hover, .table-zebra tr.hover:nth-child(2n):hover {
        --tw-bg-opacity: 1;
        background-color: var(--fallback-b3,oklch(var(--b3)/var(--tw-bg-opacity)));
    }
}

.btn {
    display: inline-flex;
    height: 3rem;
    min-height: 3rem;
    flex-shrink: 0;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    border-radius: var(--rounded-btn, .5rem);
    border-color: transparent;
    border-color: oklch(var(--btn-color, var(--b2)) / var(--tw-border-opacity));
    padding-left: 1rem;
    padding-right: 1rem;
    text-align: center;
    font-size: .875rem;
    line-height: 1em;
    gap: .5rem;
    font-weight: 600;
    text-decoration-line: none;
    transition-duration: .2s;
    transition-timing-function: cubic-bezier(0,0,.2,1);
    border-width: var(--border-btn, 1px);
    transition-property: color,background-color,border-color,opacity,box-shadow,transform;
    --tw-text-opacity: 1;
    color: var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity)));
    --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);
    --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);
    outline-color: var(--fallback-bc,oklch(var(--bc)/1));
    background-color: oklch(var(--btn-color, var(--b2)) / var(--tw-bg-opacity));
    --tw-bg-opacity: 1;
    --tw-border-opacity: 1;
}

    .btn-disabled, .btn[disabled], .btn:disabled {
        pointer-events: none;
    }

.btn-square {
    height: 3rem;
    width: 3rem;
    padding: 0;
}

:where(.btn:is(input[type=checkbox])), :where(.btn:is(input[type=radio])) {
    width: auto;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

.btn:is(input[type=checkbox]):after, .btn:is(input[type=radio]):after {
    --tw-content: attr(aria-label);
    content: var(--tw-content);
}

.card {
    position: relative;
    display: flex;
    flex-direction: column;
    border-radius: var(--rounded-box, 1rem);
}

    .card:focus {
        outline: 2px solid transparent;
        outline-offset: 2px;
    }

.card-body {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    padding: var(--padding-card, 2rem);
    gap: .5rem;
}

    .card-body :where(p) {
        flex-grow: 1;
    }

.card-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: .5rem;
}

.card figure {
    display: flex;
    align-items: center;
    justify-content: center;
}

.card.image-full {
    display: grid;
}

    .card.image-full:before {
        position: relative;
        content: "";
        z-index: 10;
        border-radius: var(--rounded-box, 1rem);
        --tw-bg-opacity: 1;
        background-color: var(--fallback-n,oklch(var(--n)/var(--tw-bg-opacity)));
        opacity: .75;
    }

    .card.image-full:before, .card.image-full > * {
        grid-column-start: 1;
        grid-row-start: 1;
    }

    .card.image-full > figure img {
        height: 100%;
        -o-object-fit: cover;
        object-fit: cover;
    }

    .card.image-full > .card-body {
        position: relative;
        z-index: 20;
        --tw-text-opacity: 1;
        color: var(--fallback-nc,oklch(var(--nc)/var(--tw-text-opacity)));
    }

.carousel {
    display: inline-flex;
    overflow-x: scroll;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -ms-overflow-style: none;
    scrollbar-width: none;
}

.carousel-item {
    box-sizing: content-box;
    display: flex;
    flex: none;
    scroll-snap-align: start;
}

.carousel-start .carousel-item {
    scroll-snap-align: start;
}

.carousel-center .carousel-item {
    scroll-snap-align: center;
}

.carousel-end .carousel-item {
    scroll-snap-align: end;
}

.chat {
    display: grid;
    grid-template-columns: repeat(2,minmax(0,1fr));
    -moz-column-gap: .75rem;
    column-gap: .75rem;
    padding-top: .25rem;
    padding-bottom: .25rem;
}

.checkbox {
    flex-shrink: 0;
    --chkbg: var(--fallback-bc,oklch(var(--bc)/1));
    --chkfg: var(--fallback-b1,oklch(var(--b1)/1));
    height: 1.5rem;
    width: 1.5rem;
    cursor: pointer;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: var(--rounded-btn, .5rem);
    border-width: 1px;
    border-color: var(--fallback-bc,oklch(var(--bc)/var(--tw-border-opacity)));
    --tw-border-opacity: .2;
}

.collapse:not(td):not(tr):not(colgroup) {
    visibility: visible;
}

.collapse {
    position: relative;
    display: grid;
    overflow: hidden;
    grid-template-rows: max-content 0fr;
    transition: grid-template-rows .2s;
    width: 100%;
    border-radius: var(--rounded-box, 1rem);
}

    .collapse-title, .collapse > input[type=checkbox], .collapse > input[type=radio], .collapse-content {
        grid-column-start: 1;
        grid-row-start: 1;
    }

    .collapse > input[type=checkbox], .collapse > input[type=radio] {
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
        opacity: 0;
    }

:where(.collapse>input[type=checkbox]), :where(.collapse>input[type=radio]) {
    height: 100%;
    width: 100%;
    z-index: 1;
}

.collapse-content {
    visibility: hidden;
    grid-column-start: 1;
    grid-row-start: 2;
    min-height: 0px;
    transition: visibility .2s;
    transition: padding .2s ease-out,background-color .2s ease-out;
    padding-left: 1rem;
    padding-right: 1rem;
    cursor: unset;
}

.collapse[open], .collapse-open, .collapse:focus:not(.collapse-close) {
    grid-template-rows: max-content 1fr;
}

.collapse:not(.collapse-close):has(>input[type=checkbox]:checked), .collapse:not(.collapse-close):has(>input[type=radio]:checked) {
    grid-template-rows: max-content 1fr;
}

.collapse[open] > .collapse-content, .collapse-open > .collapse-content, .collapse:focus:not(.collapse-close) > .collapse-content, .collapse:not(.collapse-close) > input[type=checkbox]:checked ~ .collapse-content, .collapse:not(.collapse-close) > input[type=radio]:checked ~ .collapse-content {
    visibility: visible;
    min-height: -moz-fit-content;
    min-height: fit-content;
}

.drawer {
    position: relative;
    display: grid;
    grid-auto-columns: max-content auto;
    width: 100%;
}

.drawer-content {
    grid-column-start: 2;
    grid-row-start: 1;
    min-width: 0px;
}

.drawer-side {
    pointer-events: none;
    position: fixed;
    inset-inline-start: 0px;
    top: 0;
    grid-column-start: 1;
    grid-row-start: 1;
    display: grid;
    width: 100%;
    grid-template-columns: repeat(1,minmax(0,1fr));
    grid-template-rows: repeat(1,minmax(0,1fr));
    align-items: flex-start;
    justify-items: start;
    overflow-x: hidden;
    overflow-y: hidden;
    overscroll-behavior: contain;
    height: 100vh;
    height: 100dvh;
}

    .drawer-side > .drawer-overlay {
        position: sticky;
        top: 0;
        place-self: stretch;
        cursor: pointer;
        background-color: transparent;
        transition-property: color,background-color,border-color,text-decoration-color,fill,stroke;
        transition-timing-function: cubic-bezier(.4,0,.2,1);
        transition-timing-function: cubic-bezier(0,0,.2,1);
        transition-duration: .2s;
    }

    .drawer-side > * {
        grid-column-start: 1;
        grid-row-start: 1;
    }

        .drawer-side > *:not(.drawer-overlay) {
            transition-property: transform;
            transition-timing-function: cubic-bezier(.4,0,.2,1);
            transition-timing-function: cubic-bezier(0,0,.2,1);
            transition-duration: .3s;
            will-change: transform;
            transform: translate(-100%);
        }

[dir=rtl] .drawer-side > *:not(.drawer-overlay) {
    transform: translate(100%);
}

.drawer-toggle {
    position: fixed;
    height: 0px;
    width: 0px;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    opacity: 0;
}

    .drawer-toggle:checked ~ .drawer-side {
        pointer-events: auto;
        visibility: visible;
        overflow-y: auto;
    }

        .drawer-toggle:checked ~ .drawer-side > *:not(.drawer-overlay) {
            transform: translate(0);
        }

.drawer-end > .drawer-toggle ~ .drawer-content {
    grid-column-start: 1;
}

.drawer-end > .drawer-toggle ~ .drawer-side {
    grid-column-start: 2;
    justify-items: end;
}

    .drawer-end > .drawer-toggle ~ .drawer-side > *:not(.drawer-overlay) {
        transform: translate(100%);
    }

[dir=rtl] .drawer-end > .drawer-toggle ~ .drawer-side > *:not(.drawer-overlay) {
    transform: translate(-100%);
}

.drawer-end > .drawer-toggle:checked ~ .drawer-side > *:not(.drawer-overlay) {
    transform: translate(0);
}

.dropdown {
    position: relative;
    display: inline-block;
}

    .dropdown > *:not(summary):focus {
        outline: 2px solid transparent;
        outline-offset: 2px;
    }

    .dropdown .dropdown-content {
        position: absolute;
    }

    .dropdown:is(:not(details)) .dropdown-content {
        visibility: hidden;
        opacity: 0;
        transform-origin: top;
        --tw-scale-x: .95;
        --tw-scale-y: .95;
        transform: translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
        transition-property: color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;
        transition-property: color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;
        transition-property: color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;
        transition-timing-function: cubic-bezier(.4,0,.2,1);
        transition-timing-function: cubic-bezier(0,0,.2,1);
        transition-duration: .2s;
    }

.dropdown-end .dropdown-content {
    inset-inline-end: 0px;
}

.dropdown-left .dropdown-content {
    bottom: auto;
    inset-inline-end: 100%;
    top: 0;
    transform-origin: right;
}

.dropdown-right .dropdown-content {
    bottom: auto;
    inset-inline-start: 100%;
    top: 0;
    transform-origin: left;
}

.dropdown-bottom .dropdown-content {
    bottom: auto;
    top: 100%;
    transform-origin: top;
}

.dropdown-top .dropdown-content {
    bottom: 100%;
    top: auto;
    transform-origin: bottom;
}

.dropdown-end.dropdown-right .dropdown-content, .dropdown-end.dropdown-left .dropdown-content {
    bottom: 0;
    top: auto;
}

.dropdown.dropdown-open .dropdown-content, .dropdown:not(.dropdown-hover):focus .dropdown-content, .dropdown:focus-within .dropdown-content {
    visibility: visible;
    opacity: 1;
}

@media (hover: hover) {
    .dropdown.dropdown-hover:hover .dropdown-content {
        visibility: visible;
        opacity: 1;
    }

    .btm-nav > *.disabled:hover, .btm-nav > *[disabled]:hover {
        pointer-events: none;
        --tw-border-opacity: 0;
        background-color: var(--fallback-n,oklch(var(--n)/var(--tw-bg-opacity)));
        --tw-bg-opacity: .1;
        color: var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity)));
        --tw-text-opacity: .2;
    }

    .btn:hover {
        --tw-border-opacity: 1;
        border-color: var(--fallback-b3,oklch(var(--b3)/var(--tw-border-opacity)));
        --tw-bg-opacity: 1;
        background-color: var(--fallback-b3,oklch(var(--b3)/var(--tw-bg-opacity)));
    }

    @supports (color: color-mix(in oklab,black,black)) {
        .btn:hover {
            background-color: color-mix(in oklab,oklch(var(--btn-color, var(--b2)) / var(--tw-bg-opacity, 1)) 90%,black);
            border-color: color-mix(in oklab,oklch(var(--btn-color, var(--b2)) / var(--tw-border-opacity, 1)) 90%,black);
        }
    }

    @supports not (color: oklch(0% 0 0)) {
        .btn:hover {
            background-color: var(--btn-color, var(--fallback-b2));
            border-color: var(--btn-color, var(--fallback-b2));
        }
    }

    .btn.glass:hover {
        --glass-opacity: 25%;
        --glass-border-opacity: 15%;
    }

    .btn-ghost:hover {
        border-color: transparent;
    }

    @supports (color: oklch(0% 0 0)) {
        .btn-ghost:hover {
            background-color: var(--fallback-bc,oklch(var(--bc)/.2));
        }
    }

    .btn-outline:hover {
        --tw-border-opacity: 1;
        border-color: var(--fallback-bc,oklch(var(--bc)/var(--tw-border-opacity)));
        --tw-bg-opacity: 1;
        background-color: var(--fallback-bc,oklch(var(--bc)/var(--tw-bg-opacity)));
        --tw-text-opacity: 1;
        color: var(--fallback-b1,oklch(var(--b1)/var(--tw-text-opacity)));
    }

    .btn-outline.btn-primary:hover {
        --tw-text-opacity: 1;
        color: var(--fallback-pc,oklch(var(--pc)/var(--tw-text-opacity)));
    }

    @supports (color: color-mix(in oklab,black,black)) {
        .btn-outline.btn-primary:hover {
            background-color: color-mix(in oklab,var(--fallback-p,oklch(var(--p)/1)) 90%,black);
            border-color: color-mix(in oklab,var(--fallback-p,oklch(var(--p)/1)) 90%,black);
        }
    }

    .btn-outline.btn-secondary:hover {
        --tw-text-opacity: 1;
        color: var(--fallback-sc,oklch(var(--sc)/var(--tw-text-opacity)));
    }

    @supports (color: color-mix(in oklab,black,black)) {
        .btn-outline.btn-secondary:hover {
            background-color: color-mix(in oklab,var(--fallback-s,oklch(var(--s)/1)) 90%,black);
            border-color: color-mix(in oklab,var(--fallback-s,oklch(var(--s)/1)) 90%,black);
        }
    }

    .btn-outline.btn-accent:hover {
        --tw-text-opacity: 1;
        color: var(--fallback-ac,oklch(var(--ac)/var(--tw-text-opacity)));
    }

    @supports (color: color-mix(in oklab,black,black)) {
        .btn-outline.btn-accent:hover {
            background-color: color-mix(in oklab,var(--fallback-a,oklch(var(--a)/1)) 90%,black);
            border-color: color-mix(in oklab,var(--fallback-a,oklch(var(--a)/1)) 90%,black);
        }
    }

    .btn-outline.btn-success:hover {
        --tw-text-opacity: 1;
        color: var(--fallback-suc,oklch(var(--suc)/var(--tw-text-opacity)));
    }

    @supports (color: color-mix(in oklab,black,black)) {
        .btn-outline.btn-success:hover {
            background-color: color-mix(in oklab,var(--fallback-su,oklch(var(--su)/1)) 90%,black);
            border-color: color-mix(in oklab,var(--fallback-su,oklch(var(--su)/1)) 90%,black);
        }
    }

    .btn-outline.btn-info:hover {
        --tw-text-opacity: 1;
        color: var(--fallback-inc,oklch(var(--inc)/var(--tw-text-opacity)));
    }

    @supports (color: color-mix(in oklab,black,black)) {
        .btn-outline.btn-info:hover {
            background-color: color-mix(in oklab,var(--fallback-in,oklch(var(--in)/1)) 90%,black);
            border-color: color-mix(in oklab,var(--fallback-in,oklch(var(--in)/1)) 90%,black);
        }
    }

    .btn-outline.btn-warning:hover {
        --tw-text-opacity: 1;
        color: var(--fallback-wac,oklch(var(--wac)/var(--tw-text-opacity)));
    }

    @supports (color: color-mix(in oklab,black,black)) {
        .btn-outline.btn-warning:hover {
            background-color: color-mix(in oklab,var(--fallback-wa,oklch(var(--wa)/1)) 90%,black);
            border-color: color-mix(in oklab,var(--fallback-wa,oklch(var(--wa)/1)) 90%,black);
        }
    }

    .btn-outline.btn-error:hover {
        --tw-text-opacity: 1;
        color: var(--fallback-erc,oklch(var(--erc)/var(--tw-text-opacity)));
    }

    @supports (color: color-mix(in oklab,black,black)) {
        .btn-outline.btn-error:hover {
            background-color: color-mix(in oklab,var(--fallback-er,oklch(var(--er)/1)) 90%,black);
            border-color: color-mix(in oklab,var(--fallback-er,oklch(var(--er)/1)) 90%,black);
        }
    }

    .btn-disabled:hover, .btn[disabled]:hover, .btn:disabled:hover {
        --tw-border-opacity: 0;
        background-color: var(--fallback-n,oklch(var(--n)/var(--tw-bg-opacity)));
        --tw-bg-opacity: .2;
        color: var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity)));
        --tw-text-opacity: .2;
    }

    @supports (color: color-mix(in oklab,black,black)) {
        .btn:is(input[type=checkbox]:checked):hover, .btn:is(input[type=radio]:checked):hover {
            background-color: color-mix(in oklab,var(--fallback-p,oklch(var(--p)/1)) 90%,black);
            border-color: color-mix(in oklab,var(--fallback-p,oklch(var(--p)/1)) 90%,black);
        }
    }

    .dropdown.dropdown-hover:hover .dropdown-content {
        --tw-scale-x: 1;
        --tw-scale-y: 1;
        transform: translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
    }

    :where(.menu li:not(.menu-title,.disabled)>*:not(ul,details,.menu-title)):not(.active,.btn):hover, :where(.menu li:not(.menu-title,.disabled)>details>summary:not(.menu-title)):not(.active,.btn):hover {
        cursor: pointer;
        outline: 2px solid transparent;
        outline-offset: 2px;
    }

    @supports (color: oklch(0% 0 0)) {
        :where(.menu li:not(.menu-title,.disabled)>*:not(ul,details,.menu-title)):not(.active,.btn):hover, :where(.menu li:not(.menu-title,.disabled)>details>summary:not(.menu-title)):not(.active,.btn):hover {
            background-color: var(--fallback-bc,oklch(var(--bc)/.1));
        }
    }
}

.dropdown:is(details) summary::-webkit-details-marker {
    display: none;
}

.footer {
    display: grid;
    width: 100%;
    grid-auto-flow: row;
    place-items: start;
    -moz-column-gap: 1rem;
    column-gap: 1rem;
    row-gap: 2.5rem;
    font-size: .875rem;
    line-height: 1.25rem;
}

    .footer > * {
        display: grid;
        place-items: start;
        gap: .5rem;
    }

@media (min-width: 48rem) {
    .footer {
        grid-auto-flow: column;
    }

    .footer-center {
        grid-auto-flow: row dense;
    }
}

.label {
    display: flex;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    align-items: center;
    justify-content: space-between;
    padding: .5rem .25rem;
}

.hero {
    display: grid;
    width: 100%;
    place-items: center;
    background-size: cover;
    background-position: center;
}

    .hero > * {
        grid-column-start: 1;
        grid-row-start: 1;
    }

.hero-overlay {
    grid-column-start: 1;
    grid-row-start: 1;
    height: 100%;
    width: 100%;
    background-color: var(--fallback-n,oklch(var(--n)/var(--tw-bg-opacity)));
    --tw-bg-opacity: .5;
}

.hero-content {
    z-index: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: 80rem;
    gap: 1rem;
    padding: 1rem;
}

.input {
    flex-shrink: 1;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    height: 3rem;
    padding-left: 1rem;
    padding-right: 1rem;
    font-size: 1rem;
    line-height: 2;
    line-height: 1.5rem;
    border-radius: var(--rounded-btn, .5rem);
    border-width: 1px;
    border-color: transparent;
    --tw-bg-opacity: 1;
    background-color: var(--fallback-b1,oklch(var(--b1)/var(--tw-bg-opacity)));
}

    .input[type=number]::-webkit-inner-spin-button, .input-md[type=number]::-webkit-inner-spin-button {
        margin-top: -1rem;
        margin-bottom: -1rem;
        margin-inline-end: -1rem;
    }

.join {
    display: inline-flex;
    align-items: stretch;
    border-radius: var(--rounded-btn, .5rem);
}

    .join :where(.join-item) {
        border-start-end-radius: 0;
        border-end-end-radius: 0;
        border-end-start-radius: 0;
        border-start-start-radius: 0;
    }

    .join .join-item:not(:first-child):not(:last-child), .join *:not(:first-child):not(:last-child) .join-item {
        border-start-end-radius: 0;
        border-end-end-radius: 0;
        border-end-start-radius: 0;
        border-start-start-radius: 0;
    }

    .join .join-item:first-child:not(:last-child), .join *:first-child:not(:last-child) .join-item {
        border-start-end-radius: 0;
        border-end-end-radius: 0;
    }

    .join .dropdown .join-item:first-child:not(:last-child), .join *:first-child:not(:last-child) .dropdown .join-item {
        border-start-end-radius: inherit;
        border-end-end-radius: inherit;
    }

    .join :where(.join-item:first-child:not(:last-child)), .join :where(*:first-child:not(:last-child) .join-item) {
        border-end-start-radius: inherit;
        border-start-start-radius: inherit;
    }

    .join .join-item:last-child:not(:first-child), .join *:last-child:not(:first-child) .join-item {
        border-end-start-radius: 0;
        border-start-start-radius: 0;
    }

    .join :where(.join-item:last-child:not(:first-child)), .join :where(*:last-child:not(:first-child) .join-item) {
        border-start-end-radius: inherit;
        border-end-end-radius: inherit;
    }

@supports not selector(:has(*)) {
    :where(.join *) {
        border-radius: inherit;
    }
}

@supports selector(:has(*)) {
    :where(.join *:has(.join-item)) {
        border-radius: inherit;
    }
}

.link {
    cursor: pointer;
    text-decoration-line: underline;
}

.menu {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    font-size: .875rem;
    line-height: 1.25rem;
    padding: .5rem;
}

    .menu :where(li ul) {
        position: relative;
        white-space: nowrap;
        margin-inline-start: 1rem;
        padding-inline-start: .5rem;
    }

    .menu :where(li:not(.menu-title)>*:not(ul,details,.menu-title,.btn)), .menu :where(li:not(.menu-title)>details>summary:not(.menu-title)) {
        display: grid;
        grid-auto-flow: column;
        align-content: flex-start;
        align-items: center;
        gap: .5rem;
        grid-auto-columns: minmax(auto,max-content) auto max-content;
        -webkit-user-select: none;
        -moz-user-select: none;
        user-select: none;
    }

    .menu li.disabled {
        cursor: not-allowed;
        -webkit-user-select: none;
        -moz-user-select: none;
        user-select: none;
        color: var(--fallback-bc,oklch(var(--bc)/.3));
    }

    .menu :where(li>.menu-dropdown:not(.menu-dropdown-show)) {
        display: none;
    }

:where(.menu li) {
    position: relative;
    display: flex;
    flex-shrink: 0;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: stretch;
}

    :where(.menu li) .badge {
        justify-self: end;
    }

.modal {
    pointer-events: none;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: 0;
    display: grid;
    height: 100%;
    max-height: none;
    width: 100%;
    max-width: none;
    justify-items: center;
    padding: 0;
    opacity: 0;
    overscroll-behavior: contain;
    z-index: 999;
    background-color: transparent;
    color: inherit;
    transition-duration: .2s;
    transition-timing-function: cubic-bezier(0,0,.2,1);
    transition-property: transform,opacity,visibility;
    overflow-y: hidden;
}

:where(.modal) {
    align-items: center;
}

.modal-box {
    max-height: calc(100vh - 5em);
    grid-column-start: 1;
    grid-row-start: 1;
    width: 91.666667%;
    max-width: 32rem;
    --tw-scale-x: .9;
    --tw-scale-y: .9;
    transform: translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
    border-bottom-right-radius: var(--rounded-box, 1rem);
    border-bottom-left-radius: var(--rounded-box, 1rem);
    border-top-left-radius: var(--rounded-box, 1rem);
    border-top-right-radius: var(--rounded-box, 1rem);
    --tw-bg-opacity: 1;
    background-color: var(--fallback-b1,oklch(var(--b1)/var(--tw-bg-opacity)));
    padding: 1.5rem;
    transition-property: color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;
    transition-property: color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;
    transition-property: color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;
    transition-timing-function: cubic-bezier(.4,0,.2,1);
    transition-timing-function: cubic-bezier(0,0,.2,1);
    transition-duration: .2s;
    box-shadow: #00000040 0 25px 50px -12px;
    overflow-y: auto;
    overscroll-behavior: contain;
}

.modal-open, .modal:target, .modal-toggle:checked + .modal, .modal[open] {
    pointer-events: auto;
    visibility: visible;
    opacity: 1;
}

.modal-action {
    display: flex;
    margin-top: 1.5rem;
    justify-content: flex-end;
}

:root:has(:is(.modal-open,.modal:target,.modal-toggle:checked+.modal,.modal[open])) {
    overflow: hidden;
    scrollbar-gutter: stable;
}

.navbar {
    display: flex;
    align-items: center;
    padding: var(--navbar-padding, .5rem);
    min-height: 4rem;
    width: 100%;
}

:where(.navbar>*:not(script,style)) {
    display: inline-flex;
    align-items: center;
}

.radio {
    flex-shrink: 0;
    --chkbg: var(--bc);
    height: 1.5rem;
    width: 1.5rem;
    cursor: pointer;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: 9999px;
    border-width: 1px;
    border-color: var(--fallback-bc,oklch(var(--bc)/var(--tw-border-opacity)));
    --tw-border-opacity: .2;
}

.select {
    display: inline-flex;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    height: 3rem;
    min-height: 3rem;
    padding-inline-start: 1rem;
    padding-inline-end: 2.5rem;
    font-size: .875rem;
    line-height: 1.25rem;
    line-height: 2;
    border-radius: var(--rounded-btn, .5rem);
    border-width: 1px;
    border-color: transparent;
    --tw-bg-opacity: 1;
    background-color: var(--fallback-b1,oklch(var(--b1)/var(--tw-bg-opacity)));
    background-image: linear-gradient(45deg,transparent 50%,currentColor 50%),linear-gradient(135deg,currentColor 50%,transparent 50%);
    background-position: calc(100% - 20px) calc(1px + 50%),calc(100% - 16.1px) calc(1px + 50%);
    background-size: 4px 4px,4px 4px;
    background-repeat: no-repeat;
}

    .select[multiple] {
        height: auto;
    }

.swap {
    position: relative;
    display: inline-grid;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    place-content: center;
    cursor: pointer;
}

    .swap > * {
        grid-column-start: 1;
        grid-row-start: 1;
        transition-duration: .3s;
        transition-timing-function: cubic-bezier(0,0,.2,1);
        transition-property: transform,opacity;
    }

    .swap input {
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
    }

        .swap .swap-on, .swap .swap-indeterminate, .swap input:indeterminate ~ .swap-on {
            opacity: 0;
        }

        .swap input:checked ~ .swap-off, .swap-active .swap-off, .swap input:indeterminate ~ .swap-off {
            opacity: 0;
        }

        .swap input:checked ~ .swap-on, .swap-active .swap-on, .swap input:indeterminate ~ .swap-indeterminate {
            opacity: 1;
        }

.tabs {
    display: grid;
    align-items: flex-end;
}

.table {
    position: relative;
    width: 100%;
    border-radius: var(--rounded-box, 1rem);
    text-align: left;
    font-size: .875rem;
    line-height: 1.25rem;
}

    .table :where(.table-pin-rows thead tr) {
        position: sticky;
        top: 0;
        z-index: 1;
        --tw-bg-opacity: 1;
        background-color: var(--fallback-b1,oklch(var(--b1)/var(--tw-bg-opacity)));
    }

    .table :where(.table-pin-rows tfoot tr) {
        position: sticky;
        bottom: 0;
        z-index: 1;
        --tw-bg-opacity: 1;
        background-color: var(--fallback-b1,oklch(var(--b1)/var(--tw-bg-opacity)));
    }

    .table :where(.table-pin-cols tr th) {
        position: sticky;
        left: 0;
        right: 0;
        --tw-bg-opacity: 1;
        background-color: var(--fallback-b1,oklch(var(--b1)/var(--tw-bg-opacity)));
    }

.textarea {
    min-height: 3rem;
    flex-shrink: 1;
    padding: .5rem 1rem;
    font-size: .875rem;
    line-height: 1.25rem;
    line-height: 2;
    border-radius: var(--rounded-btn, .5rem);
    border-width: 1px;
    border-color: transparent;
    --tw-bg-opacity: 1;
    background-color: var(--fallback-b1,oklch(var(--b1)/var(--tw-bg-opacity)));
}

.timeline {
    position: relative;
    display: flex;
}

:where(.timeline>li) {
    position: relative;
    display: grid;
    flex-shrink: 0;
    align-items: center;
    grid-template-rows: var(--timeline-row-start, minmax(0, 1fr)) auto var( --timeline-row-end, minmax(0, 1fr) );
    grid-template-columns: var(--timeline-col-start, minmax(0, 1fr)) auto var( --timeline-col-end, minmax(0, 1fr) );
}

.timeline > li > hr {
    width: 100%;
    border-width: 0px;
}

:where(.timeline>li>hr):first-child {
    grid-column-start: 1;
    grid-row-start: 2;
}

:where(.timeline>li>hr):last-child {
    grid-column-start: 3;
    grid-column-end: none;
    grid-row-start: 2;
    grid-row-end: auto;
}

.alert-success {
    border-color: var(--fallback-su,oklch(var(--su)/.2));
    --tw-text-opacity: 1;
    color: var(--fallback-suc,oklch(var(--suc)/var(--tw-text-opacity)));
    --alert-bg: var(--fallback-su,oklch(var(--su)/1));
    --alert-bg-mix: var(--fallback-b1,oklch(var(--b1)/1));
}

.avatar-group :where(.avatar) {
    overflow: hidden;
    border-radius: 9999px;
    border-width: 4px;
    --tw-border-opacity: 1;
    border-color: var(--fallback-b1,oklch(var(--b1)/var(--tw-border-opacity)));
}

.btm-nav > *:where(.active) {
    border-top-width: 2px;
    --tw-bg-opacity: 1;
    background-color: var(--fallback-b1,oklch(var(--b1)/var(--tw-bg-opacity)));
}

.btm-nav > *.disabled, .btm-nav > *[disabled] {
    pointer-events: none;
    --tw-border-opacity: 0;
    background-color: var(--fallback-n,oklch(var(--n)/var(--tw-bg-opacity)));
    --tw-bg-opacity: .1;
    color: var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity)));
    --tw-text-opacity: .2;
}

.btm-nav > * .label {
    font-size: 1rem;
    line-height: 1.5rem;
}

.breadcrumbs > ul > li > a:focus, .breadcrumbs > ol > li > a:focus {
    outline: 2px solid transparent;
    outline-offset: 2px;
}

.breadcrumbs > ul > li > a:focus-visible, .breadcrumbs > ol > li > a:focus-visible {
    outline: 2px solid currentColor;
    outline-offset: 2px;
}

.breadcrumbs > ul > li + *:before, .breadcrumbs > ol > li + *:before {
    content: "";
    margin-left: .5rem;
    margin-right: .75rem;
    display: block;
    height: .375rem;
    width: .375rem;
    --tw-rotate: 45deg;
    transform: translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
    opacity: .4;
    border-top: 1px solid;
    border-right: 1px solid;
    background-color: transparent;
}

[dir=rtl] .breadcrumbs > ul > li + *:before, [dir=rtl] .breadcrumbs > ol > li + *:before {
    --tw-rotate: -135deg;
}

@media (prefers-reduced-motion: no-preference) {
    .btn {
        animation: button-pop var(--animation-btn, .25s) ease-out;
    }
}

.btn:active:hover, .btn:active:focus {
    animation: button-pop 0s ease-out;
    transform: scale(var(--btn-focus-scale, .97));
}

@supports not (color: oklch(0% 0 0)) {
    .btn {
        background-color: var(--btn-color, var(--fallback-b2));
        border-color: var(--btn-color, var(--fallback-b2));
    }

    .btn-primary {
        --btn-color: var(--fallback-p);
    }

    .btn-secondary {
        --btn-color: var(--fallback-s);
    }

    .btn-accent {
        --btn-color: var(--fallback-a);
    }

    .prose :where(code):not(:where([class~=not-prose] *,pre *)) {
        background-color: var(--fallback-b3,oklch(var(--b3)/1));
    }
}

@supports (color: color-mix(in oklab,black,black)) {
    .btn-outline.btn-primary.btn-active {
        background-color: color-mix(in oklab,var(--fallback-p,oklch(var(--p)/1)) 90%,black);
        border-color: color-mix(in oklab,var(--fallback-p,oklch(var(--p)/1)) 90%,black);
    }

    .btn-outline.btn-secondary.btn-active {
        background-color: color-mix(in oklab,var(--fallback-s,oklch(var(--s)/1)) 90%,black);
        border-color: color-mix(in oklab,var(--fallback-s,oklch(var(--s)/1)) 90%,black);
    }

    .btn-outline.btn-accent.btn-active {
        background-color: color-mix(in oklab,var(--fallback-a,oklch(var(--a)/1)) 90%,black);
        border-color: color-mix(in oklab,var(--fallback-a,oklch(var(--a)/1)) 90%,black);
    }

    .btn-outline.btn-success.btn-active {
        background-color: color-mix(in oklab,var(--fallback-su,oklch(var(--su)/1)) 90%,black);
        border-color: color-mix(in oklab,var(--fallback-su,oklch(var(--su)/1)) 90%,black);
    }

    .btn-outline.btn-info.btn-active {
        background-color: color-mix(in oklab,var(--fallback-in,oklch(var(--in)/1)) 90%,black);
        border-color: color-mix(in oklab,var(--fallback-in,oklch(var(--in)/1)) 90%,black);
    }

    .btn-outline.btn-warning.btn-active {
        background-color: color-mix(in oklab,var(--fallback-wa,oklch(var(--wa)/1)) 90%,black);
        border-color: color-mix(in oklab,var(--fallback-wa,oklch(var(--wa)/1)) 90%,black);
    }

    .btn-outline.btn-error.btn-active {
        background-color: color-mix(in oklab,var(--fallback-er,oklch(var(--er)/1)) 90%,black);
        border-color: color-mix(in oklab,var(--fallback-er,oklch(var(--er)/1)) 90%,black);
    }
}

.btn:focus-visible {
    outline-style: solid;
    outline-width: 2px;
    outline-offset: 2px;
}

.btn-primary {
    --tw-text-opacity: 1;
    color: var(--fallback-pc,oklch(var(--pc)/var(--tw-text-opacity)));
    outline-color: var(--fallback-p,oklch(var(--p)/1));
}

@supports (color: oklch(0% 0 0)) {
    .btn-primary {
        --btn-color: var(--p);
    }

    .btn-secondary {
        --btn-color: var(--s);
    }

    .btn-accent {
        --btn-color: var(--a);
    }
}

.btn-secondary {
    --tw-text-opacity: 1;
    color: var(--fallback-sc,oklch(var(--sc)/var(--tw-text-opacity)));
    outline-color: var(--fallback-s,oklch(var(--s)/1));
}

.btn-accent {
    --tw-text-opacity: 1;
    color: var(--fallback-ac,oklch(var(--ac)/var(--tw-text-opacity)));
    outline-color: var(--fallback-a,oklch(var(--a)/1));
}

.btn.glass {
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);
    outline-color: currentColor;
}

    .btn.glass.btn-active {
        --glass-opacity: 25%;
        --glass-border-opacity: 15%;
    }

.btn-ghost {
    border-width: 1px;
    border-color: transparent;
    background-color: transparent;
    color: currentColor;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);
    outline-color: currentColor;
}

    .btn-ghost.btn-active {
        border-color: transparent;
        background-color: var(--fallback-bc,oklch(var(--bc)/.2));
    }

.btn-outline {
    border-color: currentColor;
    background-color: transparent;
    --tw-text-opacity: 1;
    color: var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity)));
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);
}

    .btn-outline.btn-active {
        --tw-border-opacity: 1;
        border-color: var(--fallback-bc,oklch(var(--bc)/var(--tw-border-opacity)));
        --tw-bg-opacity: 1;
        background-color: var(--fallback-bc,oklch(var(--bc)/var(--tw-bg-opacity)));
        --tw-text-opacity: 1;
        color: var(--fallback-b1,oklch(var(--b1)/var(--tw-text-opacity)));
    }

    .btn-outline.btn-primary {
        --tw-text-opacity: 1;
        color: var(--fallback-p,oklch(var(--p)/var(--tw-text-opacity)));
    }

        .btn-outline.btn-primary.btn-active {
            --tw-text-opacity: 1;
            color: var(--fallback-pc,oklch(var(--pc)/var(--tw-text-opacity)));
        }

    .btn-outline.btn-secondary {
        --tw-text-opacity: 1;
        color: var(--fallback-s,oklch(var(--s)/var(--tw-text-opacity)));
    }

        .btn-outline.btn-secondary.btn-active {
            --tw-text-opacity: 1;
            color: var(--fallback-sc,oklch(var(--sc)/var(--tw-text-opacity)));
        }

    .btn-outline.btn-accent {
        --tw-text-opacity: 1;
        color: var(--fallback-a,oklch(var(--a)/var(--tw-text-opacity)));
    }

        .btn-outline.btn-accent.btn-active {
            --tw-text-opacity: 1;
            color: var(--fallback-ac,oklch(var(--ac)/var(--tw-text-opacity)));
        }

    .btn-outline.btn-success {
        --tw-text-opacity: 1;
        color: var(--fallback-su,oklch(var(--su)/var(--tw-text-opacity)));
    }

        .btn-outline.btn-success.btn-active {
            --tw-text-opacity: 1;
            color: var(--fallback-suc,oklch(var(--suc)/var(--tw-text-opacity)));
        }

    .btn-outline.btn-info {
        --tw-text-opacity: 1;
        color: var(--fallback-in,oklch(var(--in)/var(--tw-text-opacity)));
    }

        .btn-outline.btn-info.btn-active {
            --tw-text-opacity: 1;
            color: var(--fallback-inc,oklch(var(--inc)/var(--tw-text-opacity)));
        }

    .btn-outline.btn-warning {
        --tw-text-opacity: 1;
        color: var(--fallback-wa,oklch(var(--wa)/var(--tw-text-opacity)));
    }

        .btn-outline.btn-warning.btn-active {
            --tw-text-opacity: 1;
            color: var(--fallback-wac,oklch(var(--wac)/var(--tw-text-opacity)));
        }

    .btn-outline.btn-error {
        --tw-text-opacity: 1;
        color: var(--fallback-er,oklch(var(--er)/var(--tw-text-opacity)));
    }

        .btn-outline.btn-error.btn-active {
            --tw-text-opacity: 1;
            color: var(--fallback-erc,oklch(var(--erc)/var(--tw-text-opacity)));
        }

.btn.btn-disabled, .btn[disabled], .btn:disabled {
    --tw-border-opacity: 0;
    background-color: var(--fallback-n,oklch(var(--n)/var(--tw-bg-opacity)));
    --tw-bg-opacity: .2;
    color: var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity)));
    --tw-text-opacity: .2;
}

.btn:is(input[type=checkbox]:checked), .btn:is(input[type=radio]:checked) {
    --tw-border-opacity: 1;
    border-color: var(--fallback-p,oklch(var(--p)/var(--tw-border-opacity)));
    --tw-bg-opacity: 1;
    background-color: var(--fallback-p,oklch(var(--p)/var(--tw-bg-opacity)));
    --tw-text-opacity: 1;
    color: var(--fallback-pc,oklch(var(--pc)/var(--tw-text-opacity)));
}

    .btn:is(input[type=checkbox]:checked):focus-visible, .btn:is(input[type=radio]:checked):focus-visible {
        outline-color: var(--fallback-p,oklch(var(--p)/1));
    }

@keyframes button-pop {
    0% {
        transform: scale(var(--btn-focus-scale, .98));
    }

    40% {
        transform: scale(1.02);
    }

    to {
        transform: scale(1);
    }
}

.card :where(figure:first-child) {
    overflow: hidden;
    border-start-start-radius: inherit;
    border-start-end-radius: inherit;
    border-end-start-radius: unset;
    border-end-end-radius: unset;
}

.card :where(figure:last-child) {
    overflow: hidden;
    border-start-start-radius: unset;
    border-start-end-radius: unset;
    border-end-start-radius: inherit;
    border-end-end-radius: inherit;
}

.card:focus-visible {
    outline: 2px solid currentColor;
    outline-offset: 2px;
}

.card.bordered {
    border-width: 1px;
    --tw-border-opacity: 1;
    border-color: var(--fallback-b2,oklch(var(--b2)/var(--tw-border-opacity)));
}

.card.compact .card-body {
    padding: 1rem;
    font-size: .875rem;
    line-height: 1.25rem;
}

.card-title {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: 1.25rem;
    line-height: 1.75rem;
    font-weight: 600;
}

.card.image-full :where(figure) {
    overflow: hidden;
    border-radius: inherit;
}

.carousel::-webkit-scrollbar {
    display: none;
}

.checkbox:focus {
    box-shadow: none;
}

.checkbox:focus-visible {
    outline-style: solid;
    outline-width: 2px;
    outline-offset: 2px;
    outline-color: var(--fallback-bc,oklch(var(--bc)/1));
}

.checkbox:disabled {
    border-width: 0px;
    cursor: not-allowed;
    border-color: transparent;
    --tw-bg-opacity: 1;
    background-color: var(--fallback-bc,oklch(var(--bc)/var(--tw-bg-opacity)));
    opacity: .2;
}

.checkbox:checked, .checkbox[aria-checked=true] {
    background-repeat: no-repeat;
    animation: checkmark var(--animation-input, .2s) ease-out;
    background-color: var(--chkbg);
    background-image: linear-gradient(-45deg,transparent 65%,var(--chkbg) 65.99%),linear-gradient(45deg,transparent 75%,var(--chkbg) 75.99%),linear-gradient(-45deg,var(--chkbg) 40%,transparent 40.99%),linear-gradient(45deg,var(--chkbg) 30%,var(--chkfg) 30.99%,var(--chkfg) 40%,transparent 40.99%),linear-gradient(-45deg,var(--chkfg) 50%,var(--chkbg) 50.99%);
}

.checkbox:indeterminate {
    --tw-bg-opacity: 1;
    background-color: var(--fallback-bc,oklch(var(--bc)/var(--tw-bg-opacity)));
    background-repeat: no-repeat;
    animation: checkmark var(--animation-input, .2s) ease-out;
    background-image: linear-gradient(90deg,transparent 80%,var(--chkbg) 80%),linear-gradient(-90deg,transparent 80%,var(--chkbg) 80%),linear-gradient(0deg,var(--chkbg) 43%,var(--chkfg) 43%,var(--chkfg) 57%,var(--chkbg) 57%);
}

@keyframes checkmark {
    0% {
        background-position-y: 5px;
    }

    50% {
        background-position-y: -2px;
    }

    to {
        background-position-y: 0;
    }
}

details.collapse {
    width: 100%;
}

    details.collapse summary {
        position: relative;
        display: block;
        outline: 2px solid transparent;
        outline-offset: 2px;
    }

        details.collapse summary::-webkit-details-marker {
            display: none;
        }

.collapse:focus-visible {
    outline-style: solid;
    outline-width: 2px;
    outline-offset: 2px;
    outline-color: var(--fallback-bc,oklch(var(--bc)/1));
}

.collapse:has(.collapse-title:focus-visible), .collapse:has(>input[type=checkbox]:focus-visible), .collapse:has(>input[type=radio]:focus-visible) {
    outline-style: solid;
    outline-width: 2px;
    outline-offset: 2px;
    outline-color: var(--fallback-bc,oklch(var(--bc)/1));
}

.collapse-arrow > .collapse-title:after {
    position: absolute;
    display: block;
    height: .5rem;
    width: .5rem;
    --tw-translate-y: -100%;
    --tw-rotate: 45deg;
    transform: translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
    transition-property: all;
    transition-timing-function: cubic-bezier(.4,0,.2,1);
    transition-timing-function: cubic-bezier(0,0,.2,1);
    transition-duration: .15s;
    transition-duration: .2s;
    top: 1.9rem;
    inset-inline-end: 1.4rem;
    content: "";
    transform-origin: 75% 75%;
    box-shadow: 2px 2px;
    pointer-events: none;
}

.collapse-plus > .collapse-title:after {
    position: absolute;
    display: block;
    height: .5rem;
    width: .5rem;
    transition-property: all;
    transition-timing-function: cubic-bezier(.4,0,.2,1);
    transition-timing-function: cubic-bezier(0,0,.2,1);
    transition-duration: .3s;
    top: .9rem;
    inset-inline-end: 1.4rem;
    content: "+";
    pointer-events: none;
}

.collapse:not(.collapse-open):not(.collapse-close) > input[type=checkbox], .collapse:not(.collapse-open):not(.collapse-close) > input[type=radio]:not(:checked), .collapse:not(.collapse-open):not(.collapse-close) > .collapse-title {
    cursor: pointer;
}

.collapse:focus:not(.collapse-open):not(.collapse-close):not(.collapse[open]) > .collapse-title {
    cursor: unset;
}

.collapse-title {
    position: relative;
}

.collapse-title, :where(.collapse>input[type=checkbox]), :where(.collapse>input[type=radio]) {
    padding: 1rem;
    padding-inline-end: 3rem;
    min-height: 3.75rem;
    transition: background-color .2s ease-out;
}

.collapse[open] > :where(.collapse-content), .collapse-open > :where(.collapse-content), .collapse:focus:not(.collapse-close) > :where(.collapse-content), .collapse:not(.collapse-close) > :where(input[type=checkbox]:checked~.collapse-content), .collapse:not(.collapse-close) > :where(input[type=radio]:checked~.collapse-content) {
    padding-bottom: 1rem;
    transition: padding .2s ease-out,background-color .2s ease-out;
}

.collapse[open].collapse-arrow > .collapse-title:after, .collapse-open.collapse-arrow > .collapse-title:after, .collapse-arrow:focus:not(.collapse-close) > .collapse-title:after, .collapse-arrow:not(.collapse-close) > input[type=checkbox]:checked ~ .collapse-title:after, .collapse-arrow:not(.collapse-close) > input[type=radio]:checked ~ .collapse-title:after {
    --tw-translate-y: -50%;
    --tw-rotate: 225deg;
    transform: translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.collapse[open].collapse-plus > .collapse-title:after, .collapse-open.collapse-plus > .collapse-title:after, .collapse-plus:focus:not(.collapse-close) > .collapse-title:after, .collapse-plus:not(.collapse-close) > input[type=checkbox]:checked ~ .collapse-title:after, .collapse-plus:not(.collapse-close) > input[type=radio]:checked ~ .collapse-title:after {
    content: "−";
}

.drawer-toggle:checked ~ .drawer-side > .drawer-overlay {
    background-color: #0006;
}

.drawer-toggle:focus-visible ~ .drawer-content label.drawer-button {
    outline-style: solid;
    outline-width: 2px;
    outline-offset: 2px;
}

.dropdown.dropdown-open .dropdown-content, .dropdown:focus .dropdown-content, .dropdown:focus-within .dropdown-content {
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    transform: translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.footer-title {
    margin-bottom: .5rem;
    font-weight: 700;
    text-transform: uppercase;
    opacity: .6;
}

.input input {
    --tw-bg-opacity: 1;
    background-color: var(--fallback-p,oklch(var(--p)/var(--tw-bg-opacity)));
    background-color: transparent;
}

    .input input:focus {
        outline: 2px solid transparent;
        outline-offset: 2px;
    }

.input[list]::-webkit-calendar-picker-indicator {
    line-height: 1em;
}

.input-bordered {
    border-color: var(--fallback-bc,oklch(var(--bc)/.2));
}

.input:focus, .input:focus-within {
    box-shadow: none;
    border-color: var(--fallback-bc,oklch(var(--bc)/.2));
    outline-style: solid;
    outline-width: 2px;
    outline-offset: 2px;
    outline-color: var(--fallback-bc,oklch(var(--bc)/.2));
}

.input:has(>input[disabled]), .input-disabled, .input:disabled, .input[disabled] {
    cursor: not-allowed;
    --tw-border-opacity: 1;
    border-color: var(--fallback-b2,oklch(var(--b2)/var(--tw-border-opacity)));
    --tw-bg-opacity: 1;
    background-color: var(--fallback-b2,oklch(var(--b2)/var(--tw-bg-opacity)));
    color: var(--fallback-bc,oklch(var(--bc)/.4));
}

    .input:has(>input[disabled])::-moz-placeholder, .input-disabled::-moz-placeholder, .input:disabled::-moz-placeholder, .input[disabled]::-moz-placeholder {
        color: var(--fallback-bc,oklch(var(--bc)/var(--tw-placeholder-opacity)));
        --tw-placeholder-opacity: .2;
    }

    .input:has(>input[disabled])::placeholder, .input-disabled::placeholder, .input:disabled::placeholder, .input[disabled]::placeholder {
        color: var(--fallback-bc,oklch(var(--bc)/var(--tw-placeholder-opacity)));
        --tw-placeholder-opacity: .2;
    }

    .input:has(>input[disabled]) > input[disabled] {
        cursor: not-allowed;
    }

.input::-webkit-date-and-time-value {
    text-align: inherit;
}

.join > :where(*:not(:first-child)) {
    margin-top: 0;
    margin-bottom: 0;
    margin-inline-start: -1px;
}

    .join > :where(*:not(:first-child)):is(.btn) {
        margin-inline-start: calc(var(--border-btn) * -1);
    }

.join-item:focus {
    isolation: isolate;
}

.link:focus {
    outline: 2px solid transparent;
    outline-offset: 2px;
}

.link:focus-visible {
    outline: 2px solid currentColor;
    outline-offset: 2px;
}

.loading {
    pointer-events: none;
    display: inline-block;
    aspect-ratio: 1 / 1;
    width: 1.5rem;
    background-color: currentColor;
    -webkit-mask-size: 100%;
    mask-size: 100%;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' stroke='black' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg transform-origin='center'%3E%3Ccircle cx='12' cy='12' r='9.5' fill='none' stroke-width='3' stroke-linecap='round'%3E%3CanimateTransform attributeName='transform' type='rotate' from='0 12 12' to='360 12 12' dur='2s' repeatCount='indefinite'/%3E%3Canimate attributeName='stroke-dasharray' values='0,150;42,150;42,150' keyTimes='0;0.475;1' dur='1.5s' repeatCount='indefinite'/%3E%3Canimate attributeName='stroke-dashoffset' values='0;-16;-59' keyTimes='0;0.475;1' dur='1.5s' repeatCount='indefinite'/%3E%3C/circle%3E%3C/g%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' stroke='black' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg transform-origin='center'%3E%3Ccircle cx='12' cy='12' r='9.5' fill='none' stroke-width='3' stroke-linecap='round'%3E%3CanimateTransform attributeName='transform' type='rotate' from='0 12 12' to='360 12 12' dur='2s' repeatCount='indefinite'/%3E%3Canimate attributeName='stroke-dasharray' values='0,150;42,150;42,150' keyTimes='0;0.475;1' dur='1.5s' repeatCount='indefinite'/%3E%3Canimate attributeName='stroke-dashoffset' values='0;-16;-59' keyTimes='0;0.475;1' dur='1.5s' repeatCount='indefinite'/%3E%3C/circle%3E%3C/g%3E%3C/svg%3E");
}

:where(.menu li:empty) {
    --tw-bg-opacity: 1;
    background-color: var(--fallback-bc,oklch(var(--bc)/var(--tw-bg-opacity)));
    opacity: .1;
    margin: .5rem 1rem;
    height: 1px;
}

.menu :where(li ul):before {
    position: absolute;
    bottom: .75rem;
    inset-inline-start: 0px;
    top: .75rem;
    width: 1px;
    --tw-bg-opacity: 1;
    background-color: var(--fallback-bc,oklch(var(--bc)/var(--tw-bg-opacity)));
    opacity: .1;
    content: "";
}

.menu :where(li:not(.menu-title)>*:not(ul,details,.menu-title,.btn)), .menu :where(li:not(.menu-title)>details>summary:not(.menu-title)) {
    border-radius: var(--rounded-btn, .5rem);
    padding: .5rem 1rem;
    text-align: start;
    transition-property: color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;
    transition-property: color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;
    transition-property: color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;
    transition-timing-function: cubic-bezier(.4,0,.2,1);
    transition-timing-function: cubic-bezier(0,0,.2,1);
    transition-duration: .2s;
    text-wrap: balance;
}

:where(.menu li:not(.menu-title,.disabled)>*:not(ul,details,.menu-title)):not(summary,.active,.btn).focus, :where(.menu li:not(.menu-title,.disabled)>*:not(ul,details,.menu-title)):not(summary,.active,.btn):focus, :where(.menu li:not(.menu-title,.disabled)>*:not(ul,details,.menu-title)):is(summary):not(.active,.btn):focus-visible, :where(.menu li:not(.menu-title,.disabled)>details>summary:not(.menu-title)):not(summary,.active,.btn).focus, :where(.menu li:not(.menu-title,.disabled)>details>summary:not(.menu-title)):not(summary,.active,.btn):focus, :where(.menu li:not(.menu-title,.disabled)>details>summary:not(.menu-title)):is(summary):not(.active,.btn):focus-visible {
    cursor: pointer;
    background-color: var(--fallback-bc,oklch(var(--bc)/.1));
    --tw-text-opacity: 1;
    color: var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity)));
    outline: 2px solid transparent;
    outline-offset: 2px;
}

.menu li > *:not(ul,.menu-title,details,.btn):active, .menu li > *:not(ul,.menu-title,details,.btn).active, .menu li > details > summary:active {
    --tw-bg-opacity: 1;
    background-color: var(--fallback-n,oklch(var(--n)/var(--tw-bg-opacity)));
    --tw-text-opacity: 1;
    color: var(--fallback-nc,oklch(var(--nc)/var(--tw-text-opacity)));
}

.menu :where(li>details>summary)::-webkit-details-marker {
    display: none;
}

.menu :where(li>details>summary):after, .menu :where(li>.menu-dropdown-toggle):after {
    justify-self: end;
    display: block;
    margin-top: -.5rem;
    height: .5rem;
    width: .5rem;
    transform: rotate(45deg);
    transition-property: transform,margin-top;
    transition-duration: .3s;
    transition-timing-function: cubic-bezier(.4,0,.2,1);
    content: "";
    transform-origin: 75% 75%;
    box-shadow: 2px 2px;
    pointer-events: none;
}

.menu :where(li>details[open]>summary):after, .menu :where(li>.menu-dropdown-toggle.menu-dropdown-show):after {
    transform: rotate(225deg);
    margin-top: 0;
}

.menu-title {
    padding: .5rem 1rem;
    font-size: .875rem;
    line-height: 1.25rem;
    font-weight: 700;
    color: var(--fallback-bc,oklch(var(--bc)/.4));
}

.mockup-phone .display {
    overflow: hidden;
    border-radius: 40px;
    margin-top: -25px;
}

.mockup-browser .mockup-browser-toolbar .input {
    position: relative;
    margin-left: auto;
    margin-right: auto;
    display: block;
    height: 1.75rem;
    width: 24rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    --tw-bg-opacity: 1;
    background-color: var(--fallback-b2,oklch(var(--b2)/var(--tw-bg-opacity)));
    padding-left: 2rem;
    direction: ltr;
}

    .mockup-browser .mockup-browser-toolbar .input:before {
        content: "";
        position: absolute;
        left: .5rem;
        top: 50%;
        aspect-ratio: 1 / 1;
        height: .75rem;
        --tw-translate-y: -50%;
        transform: translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
        border-radius: 9999px;
        border-width: 2px;
        border-color: currentColor;
        opacity: .6;
    }

    .mockup-browser .mockup-browser-toolbar .input:after {
        content: "";
        position: absolute;
        left: 1.25rem;
        top: 50%;
        height: .5rem;
        --tw-translate-y: 25%;
        --tw-rotate: -45deg;
        transform: translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
        border-radius: 9999px;
        border-width: 1px;
        border-color: currentColor;
        opacity: .6;
    }

.modal:not(dialog:not(.modal-open)), .modal::backdrop {
    background-color: #0006;
    animation: modal-pop .2s ease-out;
}

.modal-open .modal-box, .modal-toggle:checked + .modal .modal-box, .modal:target .modal-box, .modal[open] .modal-box {
    --tw-translate-y: 0px;
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    transform: translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.modal-action > :not([hidden]) ~ :not([hidden]) {
    --tw-space-x-reverse: 0;
    margin-right: calc(.5rem * var(--tw-space-x-reverse));
    margin-left: calc(.5rem * calc(1 - var(--tw-space-x-reverse)));
}

.modal-action:where([dir=rtl],[dir=rtl] *) > :not([hidden]) ~ :not([hidden]) {
    --tw-space-x-reverse: 1;
}

@keyframes modal-pop {
    0% {
        opacity: 0;
    }
}

@keyframes progress-loading {
    50% {
        background-position-x: -115%;
    }
}

.radio:focus {
    box-shadow: none;
}

.radio:focus-visible {
    outline-style: solid;
    outline-width: 2px;
    outline-offset: 2px;
    outline-color: var(--fallback-bc,oklch(var(--bc)/1));
}

.radio:checked, .radio[aria-checked=true] {
    --tw-bg-opacity: 1;
    background-color: var(--fallback-bc,oklch(var(--bc)/var(--tw-bg-opacity)));
    background-image: none;
    animation: radiomark var(--animation-input, .2s) ease-out;
    box-shadow: 0 0 0 4px var(--fallback-b1,oklch(var(--b1)/1)) inset,0 0 0 4px var(--fallback-b1,oklch(var(--b1)/1)) inset;
}

.radio:disabled {
    cursor: not-allowed;
    opacity: .2;
}

@keyframes radiomark {
    0% {
        box-shadow: 0 0 0 12px var(--fallback-b1,oklch(var(--b1)/1)) inset,0 0 0 12px var(--fallback-b1,oklch(var(--b1)/1)) inset;
    }

    50% {
        box-shadow: 0 0 0 3px var(--fallback-b1,oklch(var(--b1)/1)) inset,0 0 0 3px var(--fallback-b1,oklch(var(--b1)/1)) inset;
    }

    to {
        box-shadow: 0 0 0 4px var(--fallback-b1,oklch(var(--b1)/1)) inset,0 0 0 4px var(--fallback-b1,oklch(var(--b1)/1)) inset;
    }
}

@keyframes rating-pop {
    0% {
        transform: translateY(-.125em);
    }

    40% {
        transform: translateY(-.125em);
    }

    to {
        transform: translateY(0);
    }
}

.select-bordered {
    border-color: var(--fallback-bc,oklch(var(--bc)/.2));
}

.select:focus {
    box-shadow: none;
    border-color: var(--fallback-bc,oklch(var(--bc)/.2));
    outline-style: solid;
    outline-width: 2px;
    outline-offset: 2px;
    outline-color: var(--fallback-bc,oklch(var(--bc)/.2));
}

.select-disabled, .select:disabled, .select[disabled] {
    cursor: not-allowed;
    --tw-border-opacity: 1;
    border-color: var(--fallback-b2,oklch(var(--b2)/var(--tw-border-opacity)));
    --tw-bg-opacity: 1;
    background-color: var(--fallback-b2,oklch(var(--b2)/var(--tw-bg-opacity)));
    color: var(--fallback-bc,oklch(var(--bc)/.4));
}

    .select-disabled::-moz-placeholder, .select:disabled::-moz-placeholder, .select[disabled]::-moz-placeholder {
        color: var(--fallback-bc,oklch(var(--bc)/var(--tw-placeholder-opacity)));
        --tw-placeholder-opacity: .2;
    }

    .select-disabled::placeholder, .select:disabled::placeholder, .select[disabled]::placeholder {
        color: var(--fallback-bc,oklch(var(--bc)/var(--tw-placeholder-opacity)));
        --tw-placeholder-opacity: .2;
    }

.select-multiple, .select[multiple], .select[size].select:not([size="1"]) {
    background-image: none;
    padding-right: 1rem;
}

[dir=rtl] .select {
    background-position: calc(0% + 12px) calc(1px + 50%),calc(0% + 16px) calc(1px + 50%);
}

@keyframes skeleton {
    0% {
        background-position: 150%;
    }

    to {
        background-position: -50%;
    }
}

.table:where([dir=rtl],[dir=rtl] *) {
    text-align: right;
}

.table :where(th,td) {
    padding: .75rem 1rem;
    vertical-align: middle;
}

.table tr.active, .table tr.active:nth-child(2n), .table-zebra tbody tr:nth-child(2n) {
    --tw-bg-opacity: 1;
    background-color: var(--fallback-b2,oklch(var(--b2)/var(--tw-bg-opacity)));
}

.table-zebra tr.active, .table-zebra tr.active:nth-child(2n), .table-zebra-zebra tbody tr:nth-child(2n) {
    --tw-bg-opacity: 1;
    background-color: var(--fallback-b3,oklch(var(--b3)/var(--tw-bg-opacity)));
}

.table :where(thead tr,tbody tr:not(:last-child),tbody tr:first-child:last-child) {
    border-bottom-width: 1px;
    --tw-border-opacity: 1;
    border-bottom-color: var(--fallback-b2,oklch(var(--b2)/var(--tw-border-opacity)));
}

.table :where(thead,tfoot) {
    white-space: nowrap;
    font-size: .75rem;
    line-height: 1rem;
    font-weight: 700;
    color: var(--fallback-bc,oklch(var(--bc)/.6));
}

.table :where(tfoot) {
    border-top-width: 1px;
    --tw-border-opacity: 1;
    border-top-color: var(--fallback-b2,oklch(var(--b2)/var(--tw-border-opacity)));
}

.textarea-bordered {
    border-color: var(--fallback-bc,oklch(var(--bc)/.2));
}

.textarea:focus {
    box-shadow: none;
    border-color: var(--fallback-bc,oklch(var(--bc)/.2));
    outline-style: solid;
    outline-width: 2px;
    outline-offset: 2px;
    outline-color: var(--fallback-bc,oklch(var(--bc)/.2));
}

.textarea-disabled, .textarea:disabled, .textarea[disabled] {
    cursor: not-allowed;
    --tw-border-opacity: 1;
    border-color: var(--fallback-b2,oklch(var(--b2)/var(--tw-border-opacity)));
    --tw-bg-opacity: 1;
    background-color: var(--fallback-b2,oklch(var(--b2)/var(--tw-bg-opacity)));
    color: var(--fallback-bc,oklch(var(--bc)/.4));
}

    .textarea-disabled::-moz-placeholder, .textarea:disabled::-moz-placeholder, .textarea[disabled]::-moz-placeholder {
        color: var(--fallback-bc,oklch(var(--bc)/var(--tw-placeholder-opacity)));
        --tw-placeholder-opacity: .2;
    }

    .textarea-disabled::placeholder, .textarea:disabled::placeholder, .textarea[disabled]::placeholder {
        color: var(--fallback-bc,oklch(var(--bc)/var(--tw-placeholder-opacity)));
        --tw-placeholder-opacity: .2;
    }

.timeline hr {
    height: .25rem;
}

:where(.timeline hr) {
    --tw-bg-opacity: 1;
    background-color: var(--fallback-b3,oklch(var(--b3)/var(--tw-bg-opacity)));
}

:where(.timeline:has(.timeline-middle) hr):first-child {
    border-start-end-radius: var(--rounded-badge, 1.9rem);
    border-end-end-radius: var(--rounded-badge, 1.9rem);
    border-start-start-radius: 0px;
    border-end-start-radius: 0px;
}

:where(.timeline:has(.timeline-middle) hr):last-child {
    border-start-start-radius: var(--rounded-badge, 1.9rem);
    border-end-start-radius: var(--rounded-badge, 1.9rem);
    border-start-end-radius: 0px;
    border-end-end-radius: 0px;
}

:where(.timeline:not(:has(.timeline-middle)) :first-child hr:last-child) {
    border-start-start-radius: var(--rounded-badge, 1.9rem);
    border-end-start-radius: var(--rounded-badge, 1.9rem);
    border-start-end-radius: 0px;
    border-end-end-radius: 0px;
}

:where(.timeline:not(:has(.timeline-middle)) :last-child hr:first-child) {
    border-start-end-radius: var(--rounded-badge, 1.9rem);
    border-end-end-radius: var(--rounded-badge, 1.9rem);
    border-start-start-radius: 0px;
    border-end-start-radius: 0px;
}

@keyframes toast-pop {
    0% {
        transform: scale(.9);
        opacity: 0;
    }

    to {
        transform: scale(1);
        opacity: 1;
    }
}

:root .prose {
    --tw-prose-body: var(--fallback-bc,oklch(var(--bc)/.8));
    --tw-prose-headings: var(--fallback-bc,oklch(var(--bc)/1));
    --tw-prose-lead: var(--fallback-bc,oklch(var(--bc)/1));
    --tw-prose-links: var(--fallback-bc,oklch(var(--bc)/1));
    --tw-prose-bold: var(--fallback-bc,oklch(var(--bc)/1));
    --tw-prose-counters: var(--fallback-bc,oklch(var(--bc)/1));
    --tw-prose-bullets: var(--fallback-bc,oklch(var(--bc)/.5));
    --tw-prose-hr: var(--fallback-bc,oklch(var(--bc)/.2));
    --tw-prose-quotes: var(--fallback-bc,oklch(var(--bc)/1));
    --tw-prose-quote-borders: var(--fallback-bc,oklch(var(--bc)/.2));
    --tw-prose-captions: var(--fallback-bc,oklch(var(--bc)/.5));
    --tw-prose-code: var(--fallback-bc,oklch(var(--bc)/1));
    --tw-prose-pre-code: var(--fallback-nc,oklch(var(--nc)/1));
    --tw-prose-pre-bg: var(--fallback-n,oklch(var(--n)/1));
    --tw-prose-th-borders: var(--fallback-bc,oklch(var(--bc)/.5));
    --tw-prose-td-borders: var(--fallback-bc,oklch(var(--bc)/.2));
    --tw-prose-kbd: var(--fallback-bc,oklch(var(--bc)/.8));
}

.prose :where(code):not(:where([class~=not-prose] *,pre *)) {
    padding: 1px 8px;
    border-radius: var(--rounded-badge);
    font-weight: initial;
    background-color: var(--fallback-bc,oklch(var(--bc)/.1));
}

.prose :where(code):not(:where([class~=not-prose],[class~=not-prose] *)):before, .prose :where(code):not(:where([class~=not-prose],[class~=not-prose] *)):after {
    display: none;
}

.prose pre code {
    border-radius: 0;
    padding: 0;
}

.prose :where(tbody tr,thead):not(:where([class~=not-prose] *)) {
    border-bottom-color: var(--fallback-bc,oklch(var(--bc)/.2));
}

.btm-nav-xs > *:where(.active) {
    border-top-width: 1px;
}

.btm-nav-sm > *:where(.active) {
    border-top-width: 2px;
}

.btm-nav-md > *:where(.active) {
    border-top-width: 2px;
}

.btm-nav-lg > *:where(.active) {
    border-top-width: 4px;
}

.btn-xs {
    height: 1.5rem;
    min-height: 1.5rem;
    padding-left: .5rem;
    padding-right: .5rem;
    font-size: .75rem;
}

.btn-sm {
    height: 2rem;
    min-height: 2rem;
    padding-left: .75rem;
    padding-right: .75rem;
    font-size: .875rem;
}

.btn-md {
    height: 3rem;
    min-height: 3rem;
    padding-left: 1rem;
    padding-right: 1rem;
    font-size: .875rem;
}

.btn-lg {
    height: 4rem;
    min-height: 4rem;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
    font-size: 1.125rem;
}

.btn-square:where(.btn-xs) {
    height: 1.5rem;
    width: 1.5rem;
    padding: 0;
}

.btn-square:where(.btn-sm) {
    height: 2rem;
    width: 2rem;
    padding: 0;
}

.btn-square:where(.btn-md) {
    height: 3rem;
    width: 3rem;
    padding: 0;
}

.btn-square:where(.btn-lg) {
    height: 4rem;
    width: 4rem;
    padding: 0;
}

.btn-circle:where(.btn-xs) {
    height: 1.5rem;
    width: 1.5rem;
    border-radius: 9999px;
    padding: 0;
}

.btn-circle:where(.btn-sm) {
    height: 2rem;
    width: 2rem;
    border-radius: 9999px;
    padding: 0;
}

.btn-circle:where(.btn-md) {
    height: 3rem;
    width: 3rem;
    border-radius: 9999px;
    padding: 0;
}

.btn-circle:where(.btn-lg) {
    height: 4rem;
    width: 4rem;
    border-radius: 9999px;
    padding: 0;
}

.drawer-open > .drawer-toggle {
    display: none;
}

    .drawer-open > .drawer-toggle ~ .drawer-side {
        pointer-events: auto;
        visibility: visible;
        position: sticky;
        display: block;
        width: auto;
        overscroll-behavior: auto;
    }

        .drawer-open > .drawer-toggle ~ .drawer-side > *:not(.drawer-overlay) {
            transform: translate(0);
        }

[dir=rtl] .drawer-open > .drawer-toggle ~ .drawer-side > *:not(.drawer-overlay) {
    transform: translate(0);
}

.drawer-open > .drawer-toggle:checked ~ .drawer-side {
    pointer-events: auto;
    visibility: visible;
}

.drawer-open > .drawer-side {
    overflow-y: auto;
}

html:has(.drawer-toggle:checked) {
    overflow-y: hidden;
    scrollbar-gutter: stable;
}

.join.join-vertical {
    flex-direction: column;
}

    .join.join-vertical .join-item:first-child:not(:last-child), .join.join-vertical *:first-child:not(:last-child) .join-item {
        border-end-start-radius: 0;
        border-end-end-radius: 0;
        border-start-start-radius: inherit;
        border-start-end-radius: inherit;
    }

    .join.join-vertical .join-item:last-child:not(:first-child), .join.join-vertical *:last-child:not(:first-child) .join-item {
        border-start-start-radius: 0;
        border-start-end-radius: 0;
        border-end-start-radius: inherit;
        border-end-end-radius: inherit;
    }

.join.join-horizontal {
    flex-direction: row;
}

    .join.join-horizontal .join-item:first-child:not(:last-child), .join.join-horizontal *:first-child:not(:last-child) .join-item {
        border-end-end-radius: 0;
        border-start-end-radius: 0;
        border-end-start-radius: inherit;
        border-start-start-radius: inherit;
    }

    .join.join-horizontal .join-item:last-child:not(:first-child), .join.join-horizontal *:last-child:not(:first-child) .join-item {
        border-end-start-radius: 0;
        border-start-start-radius: 0;
        border-end-end-radius: inherit;
        border-start-end-radius: inherit;
    }

.menu-horizontal {
    display: inline-flex;
    flex-direction: row;
}

    .menu-horizontal > li:not(.menu-title) > details > ul {
        position: absolute;
    }

.avatar.online:before {
    content: "";
    position: absolute;
    z-index: 10;
    display: block;
    border-radius: 9999px;
    --tw-bg-opacity: 1;
    background-color: var(--fallback-su,oklch(var(--su)/var(--tw-bg-opacity)));
    outline-style: solid;
    outline-width: 2px;
    outline-color: var(--fallback-b1,oklch(var(--b1)/1));
    width: 15%;
    height: 15%;
    top: 7%;
    right: 7%;
}

.avatar.offline:before {
    content: "";
    position: absolute;
    z-index: 10;
    display: block;
    border-radius: 9999px;
    --tw-bg-opacity: 1;
    background-color: var(--fallback-b3,oklch(var(--b3)/var(--tw-bg-opacity)));
    outline-style: solid;
    outline-width: 2px;
    outline-color: var(--fallback-b1,oklch(var(--b1)/1));
    width: 15%;
    height: 15%;
    top: 7%;
    right: 7%;
}

.card-compact .card-body {
    padding: 1rem;
    font-size: .875rem;
    line-height: 1.25rem;
}

.card-compact .card-title {
    margin-bottom: .25rem;
}

.card-normal .card-body {
    padding: var(--padding-card, 2rem);
    font-size: 1rem;
    line-height: 1.5rem;
}

.card-normal .card-title {
    margin-bottom: .75rem;
}

.drawer-open > .drawer-toggle ~ .drawer-side > .drawer-overlay {
    cursor: default;
    background-color: transparent;
}

.join.join-vertical > :where(*:not(:first-child)) {
    margin-left: 0;
    margin-right: 0;
    margin-top: -1px;
}

    .join.join-vertical > :where(*:not(:first-child)):is(.btn) {
        margin-top: calc(var(--border-btn) * -1);
    }

.join.join-horizontal > :where(*:not(:first-child)) {
    margin-top: 0;
    margin-bottom: 0;
    margin-inline-start: -1px;
}

    .join.join-horizontal > :where(*:not(:first-child)):is(.btn) {
        margin-inline-start: calc(var(--border-btn) * -1);
        margin-top: 0;
    }

.menu-horizontal > li:not(.menu-title) > details > ul {
    margin-inline-start: 0px;
    margin-top: 1rem;
    padding-top: .5rem;
    padding-bottom: .5rem;
    padding-inline-end: .5rem;
}

.menu-horizontal > li > details > ul:before {
    content: none;
}

:where(.menu-horizontal>li:not(.menu-title)>details>ul) {
    border-radius: var(--rounded-box, 1rem);
    --tw-bg-opacity: 1;
    background-color: var(--fallback-b1,oklch(var(--b1)/var(--tw-bg-opacity)));
    --tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);
    --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);
}

.menu-xs .menu-title {
    padding: .25rem .5rem;
}

.menu-sm .menu-title {
    padding: .5rem .75rem;
}

.menu-md .menu-title {
    padding: .5rem 1rem;
}

.menu-lg .menu-title {
    padding: .75rem 1.5rem;
}

.modal-top :where(.modal-box) {
    width: 100%;
    max-width: none;
    --tw-translate-y: -2.5rem;
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    transform: translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
    border-bottom-right-radius: var(--rounded-box, 1rem);
    border-bottom-left-radius: var(--rounded-box, 1rem);
    border-top-left-radius: 0;
    border-top-right-radius: 0;
}

.modal-middle :where(.modal-box) {
    width: 91.666667%;
    max-width: 32rem;
    --tw-translate-y: 0px;
    --tw-scale-x: .9;
    --tw-scale-y: .9;
    transform: translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
    border-top-left-radius: var(--rounded-box, 1rem);
    border-top-right-radius: var(--rounded-box, 1rem);
    border-bottom-right-radius: var(--rounded-box, 1rem);
    border-bottom-left-radius: var(--rounded-box, 1rem);
}

.modal-bottom :where(.modal-box) {
    width: 100%;
    max-width: none;
    --tw-translate-y: 2.5rem;
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    transform: translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
    border-top-left-radius: var(--rounded-box, 1rem);
    border-top-right-radius: var(--rounded-box, 1rem);
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
}

.visible {
    visibility: visible;
}

.collapse {
    visibility: collapse;
}

.absolute {
    position: absolute;
}

.relative {
    position: relative;
}

.sticky {
    position: sticky;
}

.inset-0 {
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
}

.bottom-\[2rem\] {
    bottom: 2rem;
}

.left-0 {
    left: 0;
}

.left-1\/2 {
    left: 50%;
}

.right-0 {
    right: 0;
}

.top-1\/4 {
    top: 25%;
}

.top-16 {
    top: 4rem;
}

.top-8 {
    top: 2rem;
}

.z-50 {
    z-index: 50;
}

.z-\[1\] {
    z-index: 1;
}

.order-1 {
    order: 1;
}

.order-2 {
    order: 2;
}

.order-3 {
    order: 3;
}

.order-4 {
    order: 4;
}

.order-5 {
    order: 5;
}

.order-6 {
    order: 6;
}

.col-span-12 {
    grid-column: span 12 / span 12;
}

.col-span-3 {
    grid-column: span 3 / span 3;
}

.col-span-6 {
    grid-column: span 6 / span 6;
}

.m-0 {
    margin: 0;
}

.m-auto {
    margin: auto;
}

.mx-10 {
    margin-left: 2.5rem;
    margin-right: 2.5rem;
}

.mx-2 {
    margin-left: .5rem;
    margin-right: .5rem;
}

.mx-5 {
    margin-left: 1.25rem;
    margin-right: 1.25rem;
}

.mx-auto {
    margin-left: auto;
    margin-right: auto;
}

.my-10 {
    margin-top: 2.5rem;
    margin-bottom: 2.5rem;
}

.my-3 {
    margin-top: .75rem;
    margin-bottom: .75rem;
}

.my-5 {
    margin-top: 1.25rem;
    margin-bottom: 1.25rem;
}

.my-8 {
    margin-top: 2rem;
    margin-bottom: 2rem;
}

.-ml-4 {
    margin-left: -1rem;
}

.-mt-4 {
    margin-top: -1rem;
}

.mb-0 {
    margin-bottom: 0;
}

.mb-1 {
    margin-bottom: .25rem;
}

.mb-12 {
    margin-bottom: 3rem;
}

.mb-2 {
    margin-bottom: .5rem;
}

.mb-3 {
    margin-bottom: .75rem;
}

.mb-4 {
    margin-bottom: 1rem;
}

.mb-5 {
    margin-bottom: 1.25rem;
}

.mb-6 {
    margin-bottom: 1.5rem;
}

.mb-8 {
    margin-bottom: 2rem;
}

.ml-2 {
    margin-left: .5rem;
}

.ml-3 {
    margin-left: .75rem;
}

.ml-5 {
    margin-left: 1.25rem;
}

.ml-\[60px\] {
    margin-left: 60px;
}

.mr-2 {
    margin-right: .5rem;
}

.mr-3 {
    margin-right: .75rem;
}

.mt-0 {
    margin-top: 0;
}

.mt-1 {
    margin-top: .25rem;
}

.mt-10 {
    margin-top: 2.5rem;
}

.mt-12 {
    margin-top: 3rem;
}

.mt-16 {
    margin-top: 4rem;
}

.mt-2 {
    margin-top: .5rem;
}

.mt-20 {
    margin-top: 5rem;
}

.mt-3 {
    margin-top: .75rem;
}

.mt-4 {
    margin-top: 1rem;
}

.mt-5 {
    margin-top: 1.25rem;
}

.mt-6 {
    margin-top: 1.5rem;
}

.mt-8, .mt-\[2rem\] {
    margin-top: 2rem;
}

.mt-\[62px\] {
    margin-top: 62px;
}

.block {
    display: block;
}

.inline-block {
    display: inline-block;
}

.inline {
    display: inline;
}

.flex {
    display: flex;
}

.inline-flex {
    display: inline-flex;
}

.table {
    display: table;
}

.grid {
    display: grid;
}

.contents {
    display: contents;
}

.hidden {
    display: none;
}

.aspect-auto {
    aspect-ratio: auto;
}

.aspect-video {
    aspect-ratio: 16 / 9;
}

.h-12 {
    height: 3rem;
}

.h-2 {
    height: .5rem;
}

.h-4 {
    height: 1rem;
}

.h-40 {
    height: 10rem;
}

.h-5 {
    height: 1.25rem;
}

.h-52 {
    height: 13rem;
}

.h-56 {
    height: 14rem;
}

.h-64 {
    height: 16rem;
}

.h-8 {
    height: 2rem;
}

.h-80 {
    height: 20rem;
}

.h-96 {
    height: 24rem;
}

.h-\[1000px\] {
    height: 1000px;
}

.h-\[15px\] {
    height: 15px;
}

.h-\[24px\] {
    height: 24px;
}

.h-\[300px\] {
    height: 300px;
}

.h-\[60px\] {
    height: 60px;
}

.h-full {
    height: 100%;
}

.min-h-44 {
    min-height: 11rem;
}

.min-h-80 {
    min-height: 20rem;
}

.min-h-96 {
    min-height: 24rem;
}

.min-h-full {
    min-height: 100%;
}

.min-h-screen {
    min-height: 100vh;
}

.w-12 {
    width: 3rem;
}

.w-2 {
    width: .5rem;
}

.w-4 {
    width: 1rem;
}

.w-40 {
    width: 10rem;
}

.w-5 {
    width: 1.25rem;
}

.w-8 {
    width: 2rem;
}

.w-80 {
    width: 20rem;
}

.w-\[100px\] {
    width: 100px;
}

.w-\[15px\] {
    width: 15px;
}

.w-\[24px\] {
    width: 24px;
}

.w-\[60px\] {
    width: 60px;
}

.w-\[80px\] {
    width: 80px;
}

.w-auto {
    width: auto;
}

.w-full {
    width: 100%;
}

.min-w-52 {
    min-width: 13rem;
}

.min-w-96 {
    min-width: 24rem;
}

.max-w-2xl {
    max-width: 42rem;
}

.max-w-3xl {
    max-width: 48rem;
}

.max-w-40 {
    max-width: 10rem;
}

.max-w-4xl {
    max-width: 56rem;
}

.max-w-5xl {
    max-width: 64rem;
}

.max-w-7xl {
    max-width: 80rem;
}

.max-w-\[300px\] {
    max-width: 300px;
}

.max-w-\[400px\] {
    max-width: 400px;
}

.max-w-\[800px\] {
    max-width: 800px;
}

.max-w-lg {
    max-width: 32rem;
}

.max-w-md {
    max-width: 28rem;
}

.max-w-none {
    max-width: none;
}

.max-w-screen-md {
    max-width: 768px;
}

.max-w-screen-sm {
    max-width: 640px;
}

.max-w-sm {
    max-width: 24rem;
}

.max-w-xl {
    max-width: 36rem;
}

.max-w-xs {
    max-width: 20rem;
}

.flex-1 {
    flex: 1 1 0%;
}

.flex-none {
    flex: none;
}

.flex-shrink-0, .shrink-0 {
    flex-shrink: 0;
}

.grow {
    flex-grow: 1;
}

.transform {
    transform: translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

.animate-spin {
    animation: spin 1s linear infinite;
}

.cursor-pointer {
    cursor: pointer;
}

.list-disc {
    list-style-type: disc;
}

.grid-cols-1 {
    grid-template-columns: repeat(1,minmax(0,1fr));
}

.grid-cols-12 {
    grid-template-columns: repeat(12,minmax(0,1fr));
}

.grid-cols-2 {
    grid-template-columns: repeat(2,minmax(0,1fr));
}

.flex-col {
    flex-direction: column;
}

.flex-wrap {
    flex-wrap: wrap;
}

.items-start {
    align-items: flex-start;
}

.items-end {
    align-items: flex-end;
}

.items-center {
    align-items: center;
}

.justify-start {
    justify-content: flex-start;
}

.justify-end {
    justify-content: flex-end;
}

.justify-center {
    justify-content: center;
}

.justify-between {
    justify-content: space-between;
}

.gap-0 {
    gap: 0px;
}

.gap-2 {
    gap: .5rem;
}

.gap-3 {
    gap: .75rem;
}

.gap-4 {
    gap: 1rem;
}

.gap-5 {
    gap: 1.25rem;
}

.gap-6 {
    gap: 1.5rem;
}

.gap-8 {
    gap: 2rem;
}

.gap-x-2 {
    -moz-column-gap: .5rem;
    column-gap: .5rem;
}

.gap-x-3 {
    -moz-column-gap: .75rem;
    column-gap: .75rem;
}

.space-x-3 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-x-reverse: 0;
    margin-right: calc(.75rem * var(--tw-space-x-reverse));
    margin-left: calc(.75rem * calc(1 - var(--tw-space-x-reverse)));
}

.space-y-3 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(.75rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(.75rem * var(--tw-space-y-reverse));
}

.space-y-4 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(1rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(1rem * var(--tw-space-y-reverse));
}

.space-y-5 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(1.25rem * var(--tw-space-y-reverse));
}

.space-y-6 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(1.5rem * var(--tw-space-y-reverse));
}

.space-y-8 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(2rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(2rem * var(--tw-space-y-reverse));
}

.self-end {
    align-self: flex-end;
}

.self-center {
    align-self: center;
}

.justify-self-end {
    justify-self: end;
}

.overflow-hidden {
    overflow: hidden;
}

.overflow-x-auto {
    overflow-x: auto;
}

.truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.hyphens-auto {
    -webkit-hyphens: auto;
    hyphens: auto;
}

.text-nowrap {
    text-wrap: nowrap;
}

.rounded-2xl {
    border-radius: 1rem;
}

.rounded-full {
    border-radius: 9999px;
}

.rounded-lg {
    border-radius: .5rem;
}

.rounded-md {
    border-radius: .375rem;
}

.rounded-xl {
    border-radius: .75rem;
}

.rounded-t-lg {
    border-top-left-radius: .5rem;
    border-top-right-radius: .5rem;
}

.border {
    border-width: 1px;
}

.border-0 {
    border-width: 0px;
}

.border-4 {
    border-width: 4px;
}

.border-b {
    border-bottom-width: 1px;
}

.border-black {
    --tw-border-opacity: 1;
    border-color: rgb(0 0 0 / var(--tw-border-opacity, 1));
}

.border-gray-100 {
    --tw-border-opacity: 1;
    border-color: rgb(243 244 246 / var(--tw-border-opacity, 1));
}

.border-gray-200 {
    --tw-border-opacity: 1;
    border-color: rgb(229 231 235 / var(--tw-border-opacity, 1));
}

.border-slate-200 {
    --tw-border-opacity: 1;
    border-color: rgb(226 232 240 / var(--tw-border-opacity, 1));
}

.border-t-blue-500 {
    --tw-border-opacity: 1;
    border-top-color: rgb(59 130 246 / var(--tw-border-opacity, 1));
}

.bg-base-100 {
    --tw-bg-opacity: 1;
    background-color: var(--fallback-b1,oklch(var(--b1)/var(--tw-bg-opacity, 1)));
}

.bg-base-200 {
    --tw-bg-opacity: 1;
    background-color: var(--fallback-b2,oklch(var(--b2)/var(--tw-bg-opacity, 1)));
}

.bg-black {
    --tw-bg-opacity: 1;
    background-color: rgb(0 0 0 / var(--tw-bg-opacity, 1));
}

.bg-gray-100 {
    --tw-bg-opacity: 1;
    background-color: rgb(243 244 246 / var(--tw-bg-opacity, 1));
}

.bg-green-300 {
    --tw-bg-opacity: 1;
    background-color: rgb(134 239 172 / var(--tw-bg-opacity, 1));
}

.bg-orange-500 {
    --tw-bg-opacity: 1;
    background-color: rgb(249 115 22 / var(--tw-bg-opacity, 1));
}

.bg-primary {
    --tw-bg-opacity: 1;
    background-color: var(--fallback-p,oklch(var(--p)/var(--tw-bg-opacity, 1)));
}

.bg-red-300 {
    --tw-bg-opacity: 1;
    background-color: rgb(252 165 165 / var(--tw-bg-opacity, 1));
}

.bg-transparent {
    background-color: transparent;
}

.bg-white {
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}

.bg-white\/20 {
    background-color: #fff3;
}

.bg-opacity-20 {
    --tw-bg-opacity: .2;
}

.bg-opacity-30 {
    --tw-bg-opacity: .3;
}

.bg-opacity-50 {
    --tw-bg-opacity: .5;
}

.bg-opacity-60 {
    --tw-bg-opacity: .6;
}

.bg-gradient-to-r {
    background-image: linear-gradient(to right,var(--tw-gradient-stops));
}

.bg-gradient-to-t {
    background-image: linear-gradient(to top,var(--tw-gradient-stops));
}

.from-black\/60 {
    --tw-gradient-from: rgb(0 0 0 / .6) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-gray-50 {
    --tw-gradient-from: #f9fafb var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(249 250 251 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-orange-900\/80 {
    --tw-gradient-from: rgb(124 45 18 / .8) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(124 45 18 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-white {
    --tw-gradient-from: #fff var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.via-black\/20 {
    --tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), rgb(0 0 0 / .2) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-orange-800\/60 {
    --tw-gradient-to: rgb(154 52 18 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), rgb(154 52 18 / .6) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.to-gray-100 {
    --tw-gradient-to: #f3f4f6 var(--tw-gradient-to-position);
}

.to-orange-100 {
    --tw-gradient-to: #ffedd5 var(--tw-gradient-to-position);
}

.to-transparent {
    --tw-gradient-to: transparent var(--tw-gradient-to-position);
}

.bg-cover {
    background-size: cover;
}

.bg-clip-text {
    -webkit-background-clip: text;
    background-clip: text;
}

.bg-center {
    background-position: center;
}

.bg-no-repeat {
    background-repeat: no-repeat;
}

.fill-primary {
    fill: var(--fallback-p,oklch(var(--p)/1));
}

.stroke-current {
    stroke: currentColor;
}

.object-contain {
    -o-object-fit: contain;
    object-fit: contain;
}

.object-cover {
    -o-object-fit: cover;
    object-fit: cover;
}

.object-center {
    -o-object-position: center;
    object-position: center;
}

.object-top {
    -o-object-position: top;
    object-position: top;
}

.p-10 {
    padding: 2.5rem;
}

.p-2 {
    padding: .5rem;
}

.p-3 {
    padding: .75rem;
}

.p-4 {
    padding: 1rem;
}

.p-5 {
    padding: 1.25rem;
}

.p-6 {
    padding: 1.5rem;
}

.p-8 {
    padding: 2rem;
}

.px-2 {
    padding-left: .5rem;
    padding-right: .5rem;
}

.px-4 {
    padding-left: 1rem;
    padding-right: 1rem;
}

.px-5 {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
}

.px-6 {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

.px-8 {
    padding-left: 2rem;
    padding-right: 2rem;
}

.py-1 {
    padding-top: .25rem;
    padding-bottom: .25rem;
}

.py-12 {
    padding-top: 3rem;
    padding-bottom: 3rem;
}

.py-2 {
    padding-top: .5rem;
    padding-bottom: .5rem;
}

.py-3 {
    padding-top: .75rem;
    padding-bottom: .75rem;
}

.py-4 {
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.py-5 {
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
}

.py-6 {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
}

.py-8 {
    padding-top: 2rem;
    padding-bottom: 2rem;
}

.pb-0 {
    padding-bottom: 0;
}

.pb-3 {
    padding-bottom: .75rem;
}

.pl-5 {
    padding-left: 1.25rem;
}

.pt-0 {
    padding-top: 0;
}

.text-left {
    text-align: left;
}

.text-center {
    text-align: center;
}

.text-2xl {
    font-size: 1.5rem;
    line-height: 2rem;
}

.text-3xl {
    font-size: 1.875rem;
    line-height: 2.25rem;
}

.text-4xl {
    font-size: 2.25rem;
    line-height: 2.5rem;
}

.text-5xl {
    font-size: 3rem;
    line-height: 1;
}

.text-8xl {
    font-size: 6rem;
    line-height: 1;
}

.text-lg {
    font-size: 1.25rem;
    line-height: 1.75rem;
}

.text-sm {
    font-size: .875rem;
    line-height: 1.25rem;
}

.text-xl {
    font-size: 1.25rem;
    line-height: 1.75rem;
}

.text-xs {
    font-size: .75rem;
    line-height: 1rem;
}

.font-bold {
    font-weight: 700;
}

.font-light {
    font-weight: 300;
}

.font-medium {
    font-weight: 500;
}

.font-normal {
    font-weight: 400;
}

.font-semibold {
    font-weight: 600;
}

.italic {
    font-style: italic;
}

.leading-loose {
    line-height: 2;
}

.leading-normal {
    line-height: 1.5;
}

.leading-relaxed {
    line-height: 1.625;
}

.leading-tight {
    line-height: 1.25;
}

.tracking-\[0\.5rem\] {
    letter-spacing: .5rem;
}

.tracking-wide {
    letter-spacing: .025em;
}

.text-gray-400 {
    --tw-text-opacity: 1;
    color: rgb(156 163 175 / var(--tw-text-opacity, 1));
}

.text-gray-500 {
    --tw-text-opacity: 1;
    color: rgb(107 114 128 / var(--tw-text-opacity, 1));
}

.text-gray-600 {
    --tw-text-opacity: 1;
    color: rgb(75 85 99 / var(--tw-text-opacity, 1));
}

.text-gray-700 {
    --tw-text-opacity: 1;
    color: rgb(55 65 81 / var(--tw-text-opacity, 1));
}

.text-gray-800 {
    --tw-text-opacity: 1;
    color: rgb(31 41 55 / var(--tw-text-opacity, 1));
}

.text-gray-900 {
    --tw-text-opacity: 1;
    color: rgb(17 24 39 / var(--tw-text-opacity, 1));
}

.text-orange-600 {
    --tw-text-opacity: 1;
    color: rgb(234 88 12 / var(--tw-text-opacity, 1));
}

.text-primary {
    --tw-text-opacity: 1;
    color: var(--fallback-p,oklch(var(--p)/var(--tw-text-opacity, 1)));
}

.text-red-500 {
    --tw-text-opacity: 1;
    color: rgb(239 68 68 / var(--tw-text-opacity, 1));
}

.text-red-700 {
    --tw-text-opacity: 1;
    color: rgb(185 28 28 / var(--tw-text-opacity, 1));
}

.text-transparent {
    color: transparent;
}

.text-white {
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.underline {
    text-decoration-line: underline;
}

.opacity-70 {
    opacity: .7;
}

.opacity-90 {
    opacity: .9;
}

.shadow {
    --tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);
    --tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);
}

.shadow-lg {
    --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);
    --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);
}

.shadow-md {
    --tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);
    --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);
}

.shadow-none {
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);
}

.shadow-sm {
    --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);
    --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);
}

.backdrop-blur-sm {
    --tw-backdrop-blur: blur(4px);
    -webkit-backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
    backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

.transition {
    transition-property: color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;
    transition-property: color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;
    transition-property: color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;
    transition-timing-function: cubic-bezier(.4,0,.2,1);
    transition-duration: .15s;
}

.transition-all {
    transition-property: all;
    transition-timing-function: cubic-bezier(.4,0,.2,1);
    transition-duration: .15s;
}

.transition-colors {
    transition-property: color,background-color,border-color,text-decoration-color,fill,stroke;
    transition-timing-function: cubic-bezier(.4,0,.2,1);
    transition-duration: .15s;
}

.transition-shadow {
    transition-property: box-shadow;
    transition-timing-function: cubic-bezier(.4,0,.2,1);
    transition-duration: .15s;
}

.duration-200 {
    transition-duration: .2s;
}

.duration-300 {
    transition-duration: .3s;
}

@font-face {
    font-family: Museo;
    src: url(Museo-300-CRmqObpO.otf) format("opentype");
    font-weight: 300;
    font-style: normal;
}

@font-face {
    font-family: Museo;
    src: url(Museo-500-Bap-V-1f.otf) format("opentype");
    font-weight: 500;
    font-style: normal;
}

@font-face {
    font-family: Museo;
    src: url(Museo-700-D7YTw04_.otf) format("opentype");
    font-weight: 700;
    font-style: normal;
}

@font-face {
    font-family: Museo;
    src: url(Museo-900-CdFMWUFq.ttf) format("truetype");
    font-weight: 900;
    font-style: normal;
}

:root {
    --primary-color: #F97614;
    --background: hsl(0, 0%, 100%);
    --foreground: hsl(214, 25%, 15%);
    --card: hsl(0, 0%, 100%);
    --card-foreground: hsl(214, 25%, 15%);
    --primary: #F97614;
    --primary-foreground: hsl(0, 0%, 98%);
    --primary-glow: hsl(0, 0%, 45%);
    --secondary: hsl(0, 0%, 40%);
    --secondary-foreground: hsl(0, 0%, 98%);
    --muted: hsl(210, 40%, 96.1%);
    --muted-foreground: hsl(215.4, 16.3%, 46.9%);
    --accent: hsl(25, 95%, 53%);
    --accent-foreground: hsl(0, 0%, 98%);
    --border: hsl(214.3, 31.8%, 91.4%);
    --radius: .75rem;
    --transition-smooth: all .4s cubic-bezier(.4, 0, .2, 1);
}

html {
    background-color: #f2f2f2;
    font-family: Museo,Inter,ui-sans-serif,system-ui,-apple-system,system-ui,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;
    font-weight: 300;
    font-optical-sizing: auto;
    font-style: normal;
    font-size: 16px;
}

.body-p {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
}

.content-m-top {
    margin-top: 82px;
}

.navbar {
    min-height: unset !important;
    padding: 0;
}

.navbar-container {
    position: fixed;
    right: 1.2rem;
    left: 1.2rem;
    z-index: 10;
}

.btn {
    font-size: 1rem;
    min-height: 2.5rem;
    height: 2.5rem;
}

p {
    font-size: 18px;
}

.menu {
    font-size: 1rem;
}

.blog-content p {
    margin-bottom: 1rem;
}

.blog-content a {
    color: var(--primary-color);
    text-decoration: underline;
}

.blog-content img {
    max-width: 70%;
    margin: 0 auto 1rem;
    border-radius: .5rem;
}

h1, h2, h3, h4, h5, h6 {
    line-height: 1.5;
    margin-bottom: 1rem;
}

h1 {
    font-size: 2.25rem;
}

h2 {
    font-size: 1.875rem;
}

h3 {
    font-size: 1.5rem;
}

h4 {
    font-size: 1.25rem;
}

h5 {
    font-size: 1.125rem;
}

h6 {
    font-size: 1rem;
}

.table a {
    color: var(--primary-color);
}

.p-container p, .p-container ul {
    margin-bottom: 1rem;
}

.p-container a {
    color: var(--primary-color);
    text-decoration: underline;
}

.shadow {
    box-shadow: 0 4px 16px #21182629;
}

.gpe-escudo {
    opacity: 0;
}

.collapse-title {
    min-height: unset;
}

.splide__slide img {
    width: 100%;
    height: auto;
}

.secretaria-content ul {
    margin-bottom: 1.25rem;
    list-style-type: disc;
}

    .secretaria-content ul > :not([hidden]) ~ :not([hidden]) {
        --tw-space-y-reverse: 0;
        margin-top: calc(.75rem * calc(1 - var(--tw-space-y-reverse)));
        margin-bottom: calc(.75rem * var(--tw-space-y-reverse));
    }

.secretaria-content ul {
    padding-left: 1.5rem;
}

.secretaria-content ol {
    margin-bottom: 1.25rem;
    list-style-type: decimal;
}

    .secretaria-content ol > :not([hidden]) ~ :not([hidden]) {
        --tw-space-y-reverse: 0;
        margin-top: calc(.75rem * calc(1 - var(--tw-space-y-reverse)));
        margin-bottom: calc(.75rem * var(--tw-space-y-reverse));
    }

.secretaria-content ol {
    padding-left: 1.5rem;
}

.secretaria-content img {
    max-width: 70%;
    margin: 0 auto 1rem;
    border-radius: .5rem;
    max-height: 600px;
}

.secretaria-content hr {
    margin: 1.5rem 0;
}

.secretaria-content a {
    color: var(--primary-color);
    text-decoration: underline;
}

#home-banner {
    min-height: 500px;
}

    #home-banner .gpe-escudo-container {
        position: absolute;
        right: 2rem;
        top: 2rem;
    }

.home-banner-social-container {
    position: absolute;
    left: 2rem;
    bottom: 2rem;
}

.container-link:hover > p:first-of-type {
    text-decoration: underline;
}

.loading-spinner-custom {
    width: 2rem;
    height: 2rem;
    border: 2px solid transparent;
    border-top: 2px solid #fff;
    border-radius: 50%;
    animation: spin .8s linear infinite;
}

.markdown hr {
    margin: 1.5rem 0;
}

.markdown p {
    margin-bottom: 1rem;
}

.markdown ul {
    margin-left: 1.25rem;
    margin-top: .75rem;
    list-style-position: inside;
    list-style-type: disc;
}

.markdown ol {
    margin-left: 1.25rem;
    margin-top: .75rem;
    list-style-position: inside;
    list-style-type: decimal;
}

.markdown li {
    margin-bottom: .25rem;
}

@keyframes spin {
    0% {
        transform: rotate(0);
    }

    to {
        transform: rotate(360deg);
    }
}

@media screen and (max-width: 1279px) {
    #home-banner {
        min-height: 500px;
    }

        #home-banner .gpe-escudo-container {
            top: 1rem;
            right: 1rem;
            bottom: unset;
        }

    .gpe-escudo {
        width: 100px;
    }

    .home-banner-social-container {
        position: absolute;
        left: 1rem;
        bottom: 1rem;
    }
}

@media (max-width: 767px) {
    .blog-content img {
        max-width: 100%;
    }

    .home-banner-social-container img {
        width: 40px;
    }
}

@media screen and (max-width: 639px) {
    .navbar-container {
        right: 0;
        left: 0;
    }

    .secretaria-content img {
        max-width: 100%;
    }
}

.marker\:text-primary *::marker {
    color: var(--fallback-p,oklch(var(--p)/var(--tw-text-opacity, 1)));
}

.marker\:text-primary::marker {
    color: var(--fallback-p,oklch(var(--p)/var(--tw-text-opacity, 1)));
}

.hover\:-translate-y-1:hover {
    --tw-translate-y: -.25rem;
    transform: translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.hover\:scale-105:hover {
    --tw-scale-x: 1.05;
    --tw-scale-y: 1.05;
    transform: translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.hover\:transform:hover {
    transform: translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.hover\:bg-gray-100:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(243 244 246 / var(--tw-bg-opacity, 1));
}

.hover\:bg-gray-200:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(229 231 235 / var(--tw-bg-opacity, 1));
}

.hover\:bg-gray-50:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(249 250 251 / var(--tw-bg-opacity, 1));
}

.hover\:shadow-xl:hover {
    --tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);
    --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);
}

@media (min-width: 640px) {
    .sm\:order-1 {
        order: 1;
    }

    .sm\:order-2 {
        order: 2;
    }

    .sm\:order-3 {
        order: 3;
    }

    .sm\:order-4 {
        order: 4;
    }

    .sm\:order-5 {
        order: 5;
    }

    .sm\:order-6 {
        order: 6;
    }

    .sm\:mb-0 {
        margin-bottom: 0;
    }

    .sm\:mt-0 {
        margin-top: 0;
    }

    .sm\:flex {
        display: flex;
    }

    .sm\:hidden {
        display: none;
    }

    .sm\:h-72 {
        height: 18rem;
    }

    .sm\:w-auto {
        width: auto;
    }

    .sm\:grid-cols-2 {
        grid-template-columns: repeat(2,minmax(0,1fr));
    }

    .sm\:flex-row {
        flex-direction: row;
    }

    .sm\:items-center {
        align-items: center;
    }

    .sm\:gap-0 {
        gap: 0px;
    }

    .sm\:gap-3 {
        gap: .75rem;
    }

    .sm\:gap-5 {
        gap: 1.25rem;
    }

    .sm\:rounded-b-3xl {
        border-bottom-right-radius: 1.5rem;
        border-bottom-left-radius: 1.5rem;
    }

    .sm\:pt-1 {
        padding-top: .25rem;
    }

    .sm\:text-left {
        text-align: left;
    }

    .sm\:text-right {
        text-align: right;
    }

    .sm\:text-2xl {
        font-size: 1.5rem;
        line-height: 2rem;
    }

    .sm\:text-lg {
        font-size: 1.125rem;
        line-height: 1.75rem;
    }
}

@media (min-width: 768px) {
    .md\:order-1 {
        order: 1;
    }

    .md\:order-2 {
        order: 2;
    }

    .md\:col-span-4 {
        grid-column: span 4 / span 4;
    }

    .md\:col-span-6 {
        grid-column: span 6 / span 6;
    }

    .md\:ml-\[100px\] {
        margin-left: 100px;
    }

    .md\:mt-\[4rem\] {
        margin-top: 4rem;
    }

    .md\:h-12 {
        height: 3rem;
    }

    .md\:h-\[300px\] {
        height: 300px;
    }

    .md\:h-\[400px\] {
        height: 400px;
    }

    .md\:h-\[80px\] {
        height: 80px;
    }

    .md\:min-h-96 {
        min-height: 24rem;
    }

    .md\:w-\[100px\] {
        width: 100px;
    }

    .md\:w-\[180px\] {
        width: 180px;
    }

    .md\:w-\[80px\] {
        width: 80px;
    }

    .md\:max-w-\[400px\] {
        max-width: 400px;
    }

    .md\:grid-cols-2 {
        grid-template-columns: repeat(2,minmax(0,1fr));
    }

    .md\:grid-cols-3 {
        grid-template-columns: repeat(3,minmax(0,1fr));
    }

    .md\:grid-cols-4 {
        grid-template-columns: repeat(4,minmax(0,1fr));
    }

    .md\:flex-row {
        flex-direction: row;
    }

    .md\:p-6 {
        padding: 1.5rem;
    }

    .md\:p-8 {
        padding: 2rem;
    }

    .md\:py-3 {
        padding-top: .75rem;
        padding-bottom: .75rem;
    }

    .md\:text-justify {
        text-align: justify;
    }

    .md\:text-2xl {
        font-size: 1.5rem;
        line-height: 2rem;
    }

    .md\:text-3xl {
        font-size: 1.875rem;
        line-height: 2.25rem;
    }

    .md\:text-4xl {
        font-size: 2.25rem;
        line-height: 2.5rem;
    }

    .md\:text-5xl {
        font-size: 3rem;
        line-height: 1;
    }

    .md\:text-6xl {
        font-size: 3.75rem;
        line-height: 1;
    }

    .md\:text-xl {
        font-size: 1.25rem;
        line-height: 1.75rem;
    }
}

@media (min-width: 1024px) {
    .lg\:sticky {
        position: sticky;
    }

    .lg\:col-span-1 {
        grid-column: span 1 / span 1;
    }

    .lg\:col-span-2 {
        grid-column: span 2 / span 2;
    }

    .lg\:col-span-3 {
        grid-column: span 3 / span 3;
    }

    .lg\:-mx-6 {
        margin-left: -1.5rem;
        margin-right: -1.5rem;
    }

    .lg\:mx-3 {
        margin-left: .75rem;
        margin-right: .75rem;
    }

    .lg\:mx-6 {
        margin-left: 1.5rem;
        margin-right: 1.5rem;
    }

    .lg\:ml-5 {
        margin-left: 1.25rem;
    }

    .lg\:mt-0 {
        margin-top: 0;
    }

    .lg\:block {
        display: block;
    }

    .lg\:flex {
        display: flex;
    }

    .lg\:hidden {
        display: none;
    }

    .lg\:h-40 {
        height: 10rem;
    }

    .lg\:w-1\/2 {
        width: 50%;
    }

    .lg\:w-1\/3 {
        width: 33.333333%;
    }

    .lg\:min-w-64 {
        min-width: 16rem;
    }

    .lg\:max-w-none {
        max-width: none;
    }

    .lg\:grid-cols-1 {
        grid-template-columns: repeat(1,minmax(0,1fr));
    }

    .lg\:grid-cols-2 {
        grid-template-columns: repeat(2,minmax(0,1fr));
    }

    .lg\:grid-cols-3 {
        grid-template-columns: repeat(3,minmax(0,1fr));
    }

    .lg\:grid-cols-4 {
        grid-template-columns: repeat(4,minmax(0,1fr));
    }

    .lg\:flex-row {
        flex-direction: row;
    }

    .lg\:items-center {
        align-items: center;
    }

    .lg\:text-4xl {
        font-size: 2.25rem;
        line-height: 2.5rem;
    }
}

@media (min-width: 1280px) {
    .xl\:block {
        display: block;
    }

    .xl\:grid-cols-3 {
        grid-template-columns: repeat(3,minmax(0,1fr));
    }

    .xl\:grid-cols-4 {
        grid-template-columns: repeat(4,minmax(0,1fr));
    }
}

.rtl\:rotate-180:where([dir=rtl],[dir=rtl] *) {
    --tw-rotate: 180deg;
    transform: translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.avatar-xxl {
    height: 10rem;
    width: 10rem;
}

.avatar {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    vertical-align: middle;
    font-weight: 600;
    height: 10rem;
    width: 10rem;
}
.overflow-hidden {
    overflow: hidden !important;
}

.text-center {
    text-align: center !important;
}
.card-body {
    flex: 1 1 auto;
    padding: 1.75rem 1.75rem;
}

.card-body.text-center {
  display: flex;
  justify-content: center;
  align-items: center;
}

.card {
    position: relative;
    display: flex;
    flex-direction: column;
    min-width: 0;
    word-wrap: break-word;
    background-color: #ffffff;
    background-clip: border-box;
    border: 0 solid #F7F8FA;
    border-radius: var(--rounded-box, 1rem);
}

.pt-5 {
    padding-top: 2rem !important;
}

.border-top {
    border-top: 1px solid #e2e8f0 !important;
}

.icon-primary {
    color: #ffffff;
    background-color: #333333;
}

.icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    vertical-align: middle;
    border-radius: 0.375rem;
    width: 3rem;
    height: 3rem;
}

.rounded-circle {
    border-radius: 50% !important;
}

.mt-n5 {
    margin-top: -2rem !important;
}

@media (min-width: 1200px) {
    .fs-4 {
        font-size: 1.5rem !important;
    }
}

.pt-4 {
    padding-top: 1.5rem !important;
}

.border-left {
    border-left: 7px solid #e2e8f0 !important; 
    border-color: #F97316 !important;
}

.badge-orange {
    display: inline-block;
    padding: 0.35em 0.65em;
    line-height: 1;
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
}

.tab-style-1 .nav {
    border-bottom: 3px solid rgba(255, 255, 255, 0.5);
}

.nav-tabs {
    border-bottom: 1px solid #e2e8f0;
}

.nav {
    display: flex;
    flex-wrap: wrap;
    padding-left: 0;
    margin-bottom: 0;
    list-style: none;
}

.tab-style-1 .tab-pane {
    padding-top: 20px;
}

.tab-content > .active {
    display: block;
}

.tab-content > .tab-pane {
    display: none;
}

.fade {
    transition: opacity 0.15s linear;
}

.list-group {
    display: flex;
    flex-direction: column;
    padding-left: 0;
    margin-bottom: 0;
    border-radius: 0.25rem;
}

.list-group-item:first-child {
    border-top-left-radius: inherit;
    border-top-right-radius: inherit;
}

.list-group-item {
    overflow: hidden;
}

.d-flex {
    display: flex !important;
}

.icon-sm {
    width: 2rem;
    height: 2rem;
}
.icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    vertical-align: middle;
    border-radius: 0.375rem;
    width: 3rem;
    height: 3rem;
}

.rounded {
    border-radius: 0.25rem !important;
}

.bg-white {
    background-color: #ffffff !important;
}

.mb-3 {
    margin-bottom: 1rem !important;
}

.shadow {
    box-shadow: 0px 3px 10px 0px rgba(35, 61, 99, 0.1) !important;
}

.w-100 {
    width: 100% !important;
}

.justify-content-between {
    justify-content: space-between !important;
}

.gap-2 {
    gap: 0.5rem !important;
}

.text-nowrap {
    white-space: nowrap !important;
}

small, .small {
    font-size: 0.875em;
}

  /* NAV izquierda: columna, scroll si crece */
  .dept-nav {
    display: flex;
    flex-direction: column;
    gap: .5rem;
    min-width: 250px;
    max-height: 70vh;
    overflow: auto;
  }
  .dept-link {
    background: #f5f5f5;
    border: 1px solid #e5e7eb;
    border-radius: .5rem;
    padding: .5rem .75rem;
    text-align: left;
    line-height: 1.2;
    cursor: pointer;
  }
  .dept-link.active { background:#e8eefc; color:#3f63e8; font-weight:600; }

  /* Paneles: ocultos por defecto */
  .dep-panel { display:none; }
  .dep-panel.active { display:block; }

/* Contenedor izquierdo (lista de departamentos) */
.dept-nav {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  width: 280px;
  min-width: 280px;
  max-height: 72vh;
  overflow-y: auto;
  padding-right: 0.25rem;
}

/* Botón de cada departamento */
.dept-link {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 0.65rem 0.75rem;
  border: 1px solid #e5e7eb;
  border-radius: 0.25rem !important;
  background: #fff;
  color: var(--gpe-text);
  font-weight: 600;
  font-size: 0.95rem;
  line-height: 1.2;
  cursor: pointer;
  transition: all 0.15s ease-in-out;
  text-align: left;

  /* Tamaño uniforme */
  min-height: 56px;
  max-height: 56px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.dept-link:hover {
  background: #fff8f2;
  border-color: #F97316;
}

.dept-link.active {
  background: #F97316;
  border-color: #F97316;
  color: #FFFFFF;
  font-weight: 700;
  box-shadow: 0 0 0 2px rgba(249, 115, 22, 0.15);
}

/* Línea separadora entre lista y contenido */
.dept-sep {
  width: 1px;
  background: #e5e7eb;
  margin: 0 0.75rem;
}

/* Panel derecho (contenedor de trámites) */
.dep-panel {
  display: none;
}
.dep-panel.active {
  display: block;
}

/* Tarjeta individual del trámite */
.tram-card {
    border: 1px solid #e5e7eb;
    background: #fff;
    border-radius: 0.25rem !important;
    padding: 1rem 1.25rem;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
    margin-bottom: 12px;
    transition: border 0.2s ease, box-shadow 0.2s ease;
}
.tram-card:hover {
  background: #fff8f2;
  border-color: #F97316;
  box-shadow: 0 2px 6px rgba(249, 115, 22, 0.15);
}

/* Encabezado del trámite */
.tram-title {
  font-weight: 300;
  letter-spacing: 0.3px;
  color: #1f2937;
  margin: 0 0 0.25rem 0;
  font-size: 16px !important;
}

/* Descripción del trámite */
.tram-desc {
  color: #9ca3af;
  font-size: 13px;
  line-height: 1.3;
  margin: 0;
  font-weight: 300 !important;
}

/* Enlace "Ir al trámite" */
.tram-go {
  white-space: nowrap;
  color: var(--gpe-orange);
  font-weight: 400;
  text-decoration: none;
  transition: color 0.2s ease;
  font-size: 11px !important;
}
.tram-go:hover {
  color: #ea580c;
  text-decoration: underline;
}

/* Icono de documento o servicio */
.tram-ico {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: 1px solid var(--gpe-orange-border);
  background: var(--gpe-orange-light);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gpe-orange);
  margin-right: 1.1rem;
}