/*!******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[15].oneOf[2].use[1]!./node_modules/next/dist/build/webpack/loaders/next-font-loader/index.js??ruleSet[1].rules[15].oneOf[2].use[2]!./node_modules/next/font/google/target.css?{"path":"app\\layout.tsx","import":"Space_Grotesk","arguments":[{"variable":"--font-space-grotesk","subsets":["latin"]}],"variableName":"spaceGrotesk"} ***!
  \******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* vietnamese */
@font-face {
  font-family: 'Space Grotesk';
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url(/_next/static/media/e1aab0933260df4d-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Space Grotesk';
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url(/_next/static/media/b7387a63dd068245-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Space Grotesk';
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url(/_next/static/media/36966cca54120369-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}@font-face {font-family: 'Space Grotesk Fallback';src: local("Arial");ascent-override: 89.71%;descent-override: 26.62%;line-gap-override: 0.00%;size-adjust: 109.69%
}.__className_dd5b2f {font-family: 'Space Grotesk', 'Space Grotesk Fallback';font-style: normal
}.__variable_dd5b2f {--font-space-grotesk: 'Space Grotesk', 'Space Grotesk Fallback'
}

/*!**********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[15].oneOf[2].use[1]!./node_modules/next/dist/build/webpack/loaders/next-font-loader/index.js??ruleSet[1].rules[15].oneOf[2].use[2]!./node_modules/next/font/google/target.css?{"path":"app\\layout.tsx","import":"IBM_Plex_Mono","arguments":[{"variable":"--font-ibm-plex-mono","subsets":["latin"],"weight":["400","500","700"]}],"variableName":"ibmPlexMono"} ***!
  \**********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* cyrillic-ext */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/58f386aa6b1a2a92-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/011e180705008d6f-s.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/7ba5fb2a8c88521c-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/92eeb95d069020cc-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/d3ebbfd689654d3a-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/ef4d5661765d0e49-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/d29838c109ef09b4-s.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/e40af3453d7c920a-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/99dcf268bda04fe5-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/98e207f02528a563-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/704b853f32d191d5-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/656feb427634a431-s.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/991629005c80bdf1-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/46e154b2fcbd6033-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/37786be940ec402b-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}@font-face {font-family: 'IBM Plex Mono Fallback';src: local("Arial");ascent-override: 76.16%;descent-override: 20.43%;line-gap-override: 0.00%;size-adjust: 134.59%
}.__className_05908d {font-family: 'IBM Plex Mono', 'IBM Plex Mono Fallback';font-style: normal
}.__variable_05908d {--font-ibm-plex-mono: 'IBM Plex Mono', 'IBM Plex Mono Fallback'
}

/*!*************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[15].oneOf[10].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[15].oneOf[10].use[3]!./app/globals.css ***!
  \*************************************************************************************************************************************************************************************************************************************************************/
/*! tailwindcss v4.1.18 | MIT License | https://tailwindcss.com */
@layer properties;
@layer theme, base, components, utilities;
@layer theme {
  :root, :host {
    --color-red-50: oklch(97.1% 0.013 17.38);
    --color-red-200: oklch(88.5% 0.062 18.334);
    --color-red-600: oklch(57.7% 0.245 27.325);
    --color-red-700: oklch(50.5% 0.213 27.518);
    --color-amber-600: oklch(66.6% 0.179 58.318);
    --color-emerald-50: oklch(97.9% 0.021 166.113);
    --color-emerald-200: oklch(90.5% 0.093 164.15);
    --color-emerald-300: oklch(84.5% 0.143 164.978);
    --color-emerald-700: oklch(50.8% 0.118 165.612);
    --color-teal-700: oklch(51.1% 0.096 186.391);
    --color-slate-100: oklch(96.8% 0.007 247.896);
    --color-slate-200: oklch(92.9% 0.013 255.508);
    --color-slate-300: oklch(86.9% 0.022 252.894);
    --color-slate-500: oklch(55.4% 0.046 257.417);
    --color-slate-600: oklch(44.6% 0.043 257.281);
    --color-slate-700: oklch(37.2% 0.044 257.287);
    --color-slate-800: oklch(27.9% 0.041 260.031);
    --color-slate-900: oklch(20.8% 0.042 265.755);
    --color-slate-950: oklch(12.9% 0.042 264.695);
    --color-white: #fff;
    --spacing: 0.25rem;
    --container-xs: 20rem;
    --container-md: 28rem;
    --container-lg: 32rem;
    --container-2xl: 42rem;
    --text-xs: 0.75rem;
    --text-xs--line-height: calc(1 / 0.75);
    --text-sm: 0.875rem;
    --text-sm--line-height: calc(1.25 / 0.875);
    --text-base: 1rem;
    --text-base--line-height: calc(1.5 / 1);
    --text-lg: 1.125rem;
    --text-lg--line-height: calc(1.75 / 1.125);
    --text-xl: 1.25rem;
    --text-xl--line-height: calc(1.75 / 1.25);
    --text-2xl: 1.5rem;
    --text-2xl--line-height: calc(2 / 1.5);
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --font-weight-extrabold: 800;
    --radius-md: 0.375rem;
    --radius-lg: 0.5rem;
    --radius-xl: 0.75rem;
    --default-transition-duration: 150ms;
    --default-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    --default-font-family: var(--font-space-grotesk);
    --default-mono-font-family: var(--font-ibm-plex-mono);
  }
}
@layer base {
  *, ::after, ::before, ::backdrop, ::file-selector-button {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    border: 0 solid;
  }
  html, :host {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
    font-feature-settings: var(--default-font-feature-settings, normal);
    font-variation-settings: var(--default-font-variation-settings, normal);
    -webkit-tap-highlight-color: transparent;
  }
  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;
    -webkit-text-decoration: inherit;
    text-decoration: inherit;
  }
  b, strong {
    font-weight: bolder;
  }
  code, kbd, samp, pre {
    font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
    font-feature-settings: var(--default-mono-font-feature-settings, normal);
    font-variation-settings: var(--default-mono-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: -0.25em;
  }
  sup {
    top: -0.5em;
  }
  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }
  :-moz-focusring {
    outline: auto;
  }
  progress {
    vertical-align: baseline;
  }
  summary {
    display: list-item;
  }
  ol, ul, menu {
    list-style: none;
  }
  img, svg, video, canvas, audio, iframe, embed, object {
    display: block;
    vertical-align: middle;
  }
  img, video {
    max-width: 100%;
    height: auto;
  }
  button, input, select, optgroup, textarea, ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    border-radius: 0;
    background-color: transparent;
    opacity: 1;
  }
  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }
  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }
  ::file-selector-button {
    margin-inline-end: 4px;
  }
  ::placeholder {
    opacity: 1;
  }
  @supports (not (-webkit-appearance: -apple-pay-button))  or (contain-intrinsic-size: 1px) {
    ::placeholder {
      color: currentcolor;
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
    }
  }
  textarea {
    resize: vertical;
  }
  ::-webkit-search-decoration {
    -webkit-appearance: none;
  }
  ::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
  }
  ::-webkit-datetime-edit {
    display: inline-flex;
  }
  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }
  ::-webkit-datetime-edit, ::-webkit-datetime-edit-year-field, ::-webkit-datetime-edit-month-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-minute-field, ::-webkit-datetime-edit-second-field, ::-webkit-datetime-edit-millisecond-field, ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }
  ::-webkit-calendar-picker-indicator {
    line-height: 1;
  }
  :-moz-ui-invalid {
    box-shadow: none;
  }
  button, input:where([type="button"], [type="reset"], [type="submit"]), ::file-selector-button {
    appearance: button;
  }
  ::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
    height: auto;
  }
  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }
}
@layer utilities {
  .pointer-events-auto {
    pointer-events: auto;
  }
  .pointer-events-none {
    pointer-events: none;
  }
  .visible {
    visibility: visible;
  }
  .absolute {
    position: absolute;
  }
  .fixed {
    position: fixed;
  }
  .relative {
    position: relative;
  }
  .inset-0 {
    inset: calc(var(--spacing) * 0);
  }
  .inset-x-0 {
    inset-inline: calc(var(--spacing) * 0);
  }
  .bottom-0 {
    bottom: calc(var(--spacing) * 0);
  }
  .z-50 {
    z-index: 50;
  }
  .z-\[70\] {
    z-index: 70;
  }
  .z-\[75\] {
    z-index: 75;
  }
  .z-\[80\] {
    z-index: 80;
  }
  .container {
    width: 100%;
    @media (width >= 40rem) {
      max-width: 40rem;
    }
    @media (width >= 48rem) {
      max-width: 48rem;
    }
    @media (width >= 64rem) {
      max-width: 64rem;
    }
    @media (width >= 80rem) {
      max-width: 80rem;
    }
    @media (width >= 96rem) {
      max-width: 96rem;
    }
  }
  .mx-auto {
    margin-inline: auto;
  }
  .mt-1 {
    margin-top: calc(var(--spacing) * 1);
  }
  .mt-2 {
    margin-top: calc(var(--spacing) * 2);
  }
  .mt-3 {
    margin-top: calc(var(--spacing) * 3);
  }
  .mt-4 {
    margin-top: calc(var(--spacing) * 4);
  }
  .mt-8 {
    margin-top: calc(var(--spacing) * 8);
  }
  .mb-1 {
    margin-bottom: calc(var(--spacing) * 1);
  }
  .mb-2 {
    margin-bottom: calc(var(--spacing) * 2);
  }
  .mb-3 {
    margin-bottom: calc(var(--spacing) * 3);
  }
  .line-clamp-3 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
  }
  .block {
    display: block;
  }
  .flex {
    display: flex;
  }
  .grid {
    display: grid;
  }
  .hidden {
    display: none;
  }
  .inline-flex {
    display: inline-flex;
  }
  .h-3 {
    height: calc(var(--spacing) * 3);
  }
  .h-32 {
    height: calc(var(--spacing) * 32);
  }
  .h-full {
    height: 100%;
  }
  .max-h-\[60vh\] {
    max-height: 60vh;
  }
  .max-h-\[70vh\] {
    max-height: 70vh;
  }
  .max-h-\[72vh\] {
    max-height: 72vh;
  }
  .max-h-\[78vh\] {
    max-height: 78vh;
  }
  .max-h-\[80vh\] {
    max-height: 80vh;
  }
  .max-h-\[86vh\] {
    max-height: 86vh;
  }
  .min-h-\[100vh\] {
    min-height: 100vh;
  }
  .w-\[74px\] {
    width: 74px;
  }
  .w-full {
    width: 100%;
  }
  .max-w-2xl {
    max-width: var(--container-2xl);
  }
  .max-w-\[160px\] {
    max-width: 160px;
  }
  .max-w-\[180px\] {
    max-width: 180px;
  }
  .max-w-\[240px\] {
    max-width: 240px;
  }
  .max-w-lg {
    max-width: var(--container-lg);
  }
  .max-w-md {
    max-width: var(--container-md);
  }
  .max-w-xs {
    max-width: var(--container-xs);
  }
  .flex-1 {
    flex: 1;
  }
  .shrink-0 {
    flex-shrink: 0;
  }
  .cursor-not-allowed {
    cursor: not-allowed;
  }
  .cursor-pointer {
    cursor: pointer;
  }
  .list-disc {
    list-style-type: disc;
  }
  .grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .grid-cols-7 {
    grid-template-columns: repeat(7, minmax(0, 1fr));
  }
  .flex-wrap {
    flex-wrap: wrap;
  }
  .items-center {
    align-items: center;
  }
  .items-start {
    align-items: flex-start;
  }
  .justify-between {
    justify-content: space-between;
  }
  .justify-center {
    justify-content: center;
  }
  .justify-end {
    justify-content: flex-end;
  }
  .gap-1 {
    gap: calc(var(--spacing) * 1);
  }
  .gap-2 {
    gap: calc(var(--spacing) * 2);
  }
  .gap-3 {
    gap: calc(var(--spacing) * 3);
  }
  .space-y-1 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 1) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-2 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-3 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .overflow-auto {
    overflow: auto;
  }
  .overflow-hidden {
    overflow: hidden;
  }
  .rounded {
    border-radius: 0.25rem;
  }
  .rounded-full {
    border-radius: calc(infinity * 1px);
  }
  .rounded-lg {
    border-radius: var(--radius-lg);
  }
  .rounded-md {
    border-radius: var(--radius-md);
  }
  .rounded-xl {
    border-radius: var(--radius-xl);
  }
  .rounded-b-none {
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
  }
  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }
  .border-emerald-200 {
    border-color: var(--color-emerald-200);
  }
  .border-emerald-300 {
    border-color: var(--color-emerald-300);
  }
  .border-red-200 {
    border-color: var(--color-red-200);
  }
  .border-slate-200 {
    border-color: var(--color-slate-200);
  }
  .border-slate-300 {
    border-color: var(--color-slate-300);
  }
  .border-teal-700 {
    border-color: var(--color-teal-700);
  }
  .bg-emerald-50 {
    background-color: var(--color-emerald-50);
  }
  .bg-emerald-50\/80 {
    background-color: color-mix(in srgb, oklch(97.9% 0.021 166.113) 80%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-emerald-50) 80%, transparent);
    }
  }
  .bg-red-50 {
    background-color: var(--color-red-50);
  }
  .bg-slate-100 {
    background-color: var(--color-slate-100);
  }
  .bg-slate-100\/95 {
    background-color: color-mix(in srgb, oklch(96.8% 0.007 247.896) 95%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-slate-100) 95%, transparent);
    }
  }
  .bg-slate-200 {
    background-color: var(--color-slate-200);
  }
  .bg-slate-200\/70 {
    background-color: color-mix(in srgb, oklch(92.9% 0.013 255.508) 70%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-slate-200) 70%, transparent);
    }
  }
  .bg-slate-950\/45 {
    background-color: color-mix(in srgb, oklch(12.9% 0.042 264.695) 45%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-slate-950) 45%, transparent);
    }
  }
  .bg-slate-950\/50 {
    background-color: color-mix(in srgb, oklch(12.9% 0.042 264.695) 50%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-slate-950) 50%, transparent);
    }
  }
  .bg-slate-950\/55 {
    background-color: color-mix(in srgb, oklch(12.9% 0.042 264.695) 55%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-slate-950) 55%, transparent);
    }
  }
  .bg-slate-950\/60 {
    background-color: color-mix(in srgb, oklch(12.9% 0.042 264.695) 60%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-slate-950) 60%, transparent);
    }
  }
  .bg-slate-950\/70 {
    background-color: color-mix(in srgb, oklch(12.9% 0.042 264.695) 70%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-slate-950) 70%, transparent);
    }
  }
  .bg-teal-700 {
    background-color: var(--color-teal-700);
  }
  .bg-white {
    background-color: var(--color-white);
  }
  .object-contain {
    object-fit: contain;
  }
  .object-cover {
    object-fit: cover;
  }
  .p-2 {
    padding: calc(var(--spacing) * 2);
  }
  .p-2\.5 {
    padding: calc(var(--spacing) * 2.5);
  }
  .p-3 {
    padding: calc(var(--spacing) * 3);
  }
  .p-4 {
    padding: calc(var(--spacing) * 4);
  }
  .p-5 {
    padding: calc(var(--spacing) * 5);
  }
  .p-6 {
    padding: calc(var(--spacing) * 6);
  }
  .px-0 {
    padding-inline: calc(var(--spacing) * 0);
  }
  .px-1 {
    padding-inline: calc(var(--spacing) * 1);
  }
  .px-2 {
    padding-inline: calc(var(--spacing) * 2);
  }
  .px-3 {
    padding-inline: calc(var(--spacing) * 3);
  }
  .px-4 {
    padding-inline: calc(var(--spacing) * 4);
  }
  .py-1 {
    padding-block: calc(var(--spacing) * 1);
  }
  .py-2 {
    padding-block: calc(var(--spacing) * 2);
  }
  .py-4 {
    padding-block: calc(var(--spacing) * 4);
  }
  .pt-1 {
    padding-top: calc(var(--spacing) * 1);
  }
  .pt-2 {
    padding-top: calc(var(--spacing) * 2);
  }
  .pl-5 {
    padding-left: calc(var(--spacing) * 5);
  }
  .text-center {
    text-align: center;
  }
  .text-left {
    text-align: left;
  }
  .font-mono {
    font-family: var(--font-ibm-plex-mono);
  }
  .text-2xl {
    font-size: var(--text-2xl);
    line-height: var(--tw-leading, var(--text-2xl--line-height));
  }
  .text-base {
    font-size: var(--text-base);
    line-height: var(--tw-leading, var(--text-base--line-height));
  }
  .text-lg {
    font-size: var(--text-lg);
    line-height: var(--tw-leading, var(--text-lg--line-height));
  }
  .text-sm {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
  }
  .text-xl {
    font-size: var(--text-xl);
    line-height: var(--tw-leading, var(--text-xl--line-height));
  }
  .text-xs {
    font-size: var(--text-xs);
    line-height: var(--tw-leading, var(--text-xs--line-height));
  }
  .text-\[0\.74rem\] {
    font-size: 0.74rem;
  }
  .text-\[10px\] {
    font-size: 10px;
  }
  .text-\[11px\] {
    font-size: 11px;
  }
  .text-\[12px\] {
    font-size: 12px;
  }
  .font-bold {
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
  }
  .font-extrabold {
    --tw-font-weight: var(--font-weight-extrabold);
    font-weight: var(--font-weight-extrabold);
  }
  .font-semibold {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }
  .tracking-\[0\.08em\] {
    --tw-tracking: 0.08em;
    letter-spacing: 0.08em;
  }
  .tracking-\[0\.12em\] {
    --tw-tracking: 0.12em;
    letter-spacing: 0.12em;
  }
  .whitespace-pre-wrap {
    white-space: pre-wrap;
  }
  .text-amber-600 {
    color: var(--color-amber-600);
  }
  .text-emerald-700 {
    color: var(--color-emerald-700);
  }
  .text-red-600 {
    color: var(--color-red-600);
  }
  .text-red-700 {
    color: var(--color-red-700);
  }
  .text-slate-500 {
    color: var(--color-slate-500);
  }
  .text-slate-600 {
    color: var(--color-slate-600);
  }
  .text-slate-700 {
    color: var(--color-slate-700);
  }
  .text-slate-800 {
    color: var(--color-slate-800);
  }
  .text-slate-900 {
    color: var(--color-slate-900);
  }
  .text-white {
    color: var(--color-white);
  }
  .uppercase {
    text-transform: uppercase;
  }
  .underline-offset-2 {
    text-underline-offset: 2px;
  }
  .antialiased {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  .opacity-45 {
    opacity: 45%;
  }
  .opacity-70 {
    opacity: 70%;
  }
  .opacity-80 {
    opacity: 80%;
  }
  .shadow-2xl {
    --tw-shadow: 0 25px 50px -12px var(--tw-shadow-color, rgb(0 0 0 / 0.25));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-sm {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .grayscale-\[0\.25\] {
    --tw-grayscale: grayscale(0.25);
    filter: var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,);
  }
  .backdrop-blur {
    --tw-backdrop-blur: blur(8px);
    -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, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, -webkit-backdrop-filter, backdrop-filter, display, content-visibility, overlay, pointer-events;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-all {
    transition-property: all;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .select-none {
    -webkit-user-select: none;
    user-select: none;
  }
  .hover\:bg-slate-100 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-slate-100);
      }
    }
  }
  .hover\:text-slate-700 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-slate-700);
      }
    }
  }
  .hover\:underline {
    &:hover {
      @media (hover: hover) {
        text-decoration-line: underline;
      }
    }
  }
  .hover\:shadow-md {
    &:hover {
      @media (hover: hover) {
        --tw-shadow: 0 4px 6px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 2px 4px -2px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
        box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
      }
    }
  }
  .sm\:w-\[260px\] {
    @media (width >= 40rem) {
      width: 260px;
    }
  }
  .sm\:grid-cols-2 {
    @media (width >= 40rem) {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }
  .sm\:grid-cols-3 {
    @media (width >= 40rem) {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }
  .sm\:grid-cols-4 {
    @media (width >= 40rem) {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }
  .sm\:grid-cols-10 {
    @media (width >= 40rem) {
      grid-template-columns: repeat(10, minmax(0, 1fr));
    }
  }
  .sm\:p-2 {
    @media (width >= 40rem) {
      padding: calc(var(--spacing) * 2);
    }
  }
  .sm\:p-4 {
    @media (width >= 40rem) {
      padding: calc(var(--spacing) * 4);
    }
  }
  .sm\:text-sm {
    @media (width >= 40rem) {
      font-size: var(--text-sm);
      line-height: var(--tw-leading, var(--text-sm--line-height));
    }
  }
  .lg\:grid-cols-\[260px_1fr\] {
    @media (width >= 64rem) {
      grid-template-columns: 260px 1fr;
    }
  }
  .xl\:col-span-2 {
    @media (width >= 80rem) {
      grid-column: span 2 / span 2;
    }
  }
  .xl\:grid-cols-2 {
    @media (width >= 80rem) {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }
  .xl\:grid-cols-\[0\.8fr_1\.2fr\] {
    @media (width >= 80rem) {
      grid-template-columns: 0.8fr 1.2fr;
    }
  }
  .xl\:grid-cols-\[1fr_1\.2fr\] {
    @media (width >= 80rem) {
      grid-template-columns: 1fr 1.2fr;
    }
  }
  .xl\:grid-cols-\[1fr_1fr_1\.1fr\] {
    @media (width >= 80rem) {
      grid-template-columns: 1fr 1fr 1.1fr;
    }
  }
}
:root {
  --bg-base: #f4f8ff;
  --bg-accent: #dbeafe;
  --bg-accent-2: #d1fae5;
  --bg-accent-3: #fef3c7;
  --ink: #0f172a;
  --ink-muted: #475569;
  --card: rgba(255, 255, 255, 0.74);
  --card-strong: rgba(255, 255, 255, 0.9);
  --stroke: rgba(15, 23, 42, 0.1);
  --brand: #0d9488;
  --brand-strong: #0369a1;
  --brand-soft: #ecfeff;
  --danger: #b91c1c;
  --success: #166534;
}
:root[data-theme="dark"],
html.dark {
  --bg-base: #06111c;
  --bg-accent: #172554;
  --bg-accent-2: #0f3b38;
  --bg-accent-3: #3a2d0f;
  --ink: #e2e8f0;
  --ink-muted: #94a3b8;
  --card: rgba(9, 18, 30, 0.78);
  --card-strong: rgba(15, 23, 42, 0.9);
  --stroke: rgba(148, 163, 184, 0.24);
  --brand: #0f766e;
  --brand-strong: #0b5f89;
  --brand-soft: rgba(15, 23, 42, 0.85);
  --danger: #991b1b;
  --success: #22c55e;
}
* {
  box-sizing: border-box;
}
body {
  margin: 0;
  min-height: 100vh;
  color: var(--ink);
  background: radial-gradient(circle at 0% 0%, var(--bg-accent) 0%, transparent 45%),
    radial-gradient(circle at 100% 0%, var(--bg-accent-2) 0%, transparent 42%),
    radial-gradient(circle at 30% 100%, var(--bg-accent-3) 0%, transparent 40%),
    var(--bg-base);
}
a {
  color: inherit;
  text-decoration: none;
}
main {
  width: 100%;
}
.qb-shell {
  width: min(1120px, 100% - 1.25rem);
  margin-inline: auto;
  padding-block: 1rem calc(7.8rem + env(safe-area-inset-bottom, 0px));
}
.qb-card {
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: 1.2rem;
  backdrop-filter: blur(14px);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.9) inset,
    0 14px 34px rgba(15, 23, 42, 0.08);
}
:root[data-theme="dark"] .qb-card,
html.dark .qb-card {
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.04) inset,
    0 16px 36px rgba(2, 6, 23, 0.45);
}
.qb-card-strong {
  background: var(--card-strong);
}
.qb-button {
  border: 0;
  border-radius: 0.85rem;
  padding: 0.62rem 0.92rem;
  font-weight: 600;
  cursor: pointer;
  transition: transform 150ms ease,
    box-shadow 150ms ease,
    background 150ms ease,
    border-color 150ms ease;
}
.qb-button:hover {
  transform: translateY(-1px) scale(1.01);
}
.qb-button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}
.qb-button-primary {
  color: #fff;
  background: linear-gradient(135deg, var(--brand), var(--brand-strong));
  box-shadow: 0 10px 20px rgba(13, 148, 136, 0.24);
}
:root[data-theme="dark"] .qb-button-primary,
html.dark .qb-button-primary {
  background: linear-gradient(135deg, #0f766e, #075985);
  box-shadow: 0 8px 16px rgba(8, 47, 73, 0.45);
}
.qb-button-muted {
  background: var(--brand-soft);
  border: 1px solid #cbd5e1;
}
:root[data-theme="dark"] .qb-button-muted,
html.dark .qb-button-muted {
  border-color: #334155;
  color: #cbd5e1;
}
.qb-button-danger {
  color: #fff;
  background: linear-gradient(135deg, #ef4444, #dc2626);
  box-shadow: 0 8px 16px rgba(220, 38, 38, 0.28);
}
:root[data-theme="dark"] .qb-button-danger,
html.dark .qb-button-danger {
  background: linear-gradient(135deg, #7f1d1d, #5f1515);
  box-shadow: 0 8px 16px rgba(95, 21, 21, 0.5);
}
.qb-input,
.qb-select,
.qb-textarea {
  width: 100%;
  border: 1px solid #cbd5e1;
  border-radius: 0.8rem;
  background: rgba(255, 255, 255, 0.86);
  color: var(--ink);
  padding: 0.6rem 0.75rem;
  transition: border-color 150ms ease, box-shadow 150ms ease, background 150ms ease;
}
:root[data-theme="dark"] .qb-input,
:root[data-theme="dark"] .qb-select,
:root[data-theme="dark"] .qb-textarea,
html.dark .qb-input,
html.dark .qb-select,
html.dark .qb-textarea {
  border-color: #334155;
  background: rgba(15, 23, 42, 0.82);
  color: #e2e8f0;
}
:root[data-theme="dark"] .qb-input::placeholder,
:root[data-theme="dark"] .qb-textarea::placeholder,
html.dark .qb-input::placeholder,
html.dark .qb-textarea::placeholder {
  color: #94a3b8;
}
.qb-input:focus,
.qb-select:focus,
.qb-textarea:focus {
  outline: 2px solid rgba(13, 148, 136, 0.2);
  border-color: var(--brand);
  box-shadow: 0 0 0 4px rgba(13, 148, 136, 0.09);
}
.qb-tag {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  font-size: 0.72rem;
  line-height: 1;
  padding: 0.3rem 0.6rem;
  border: 1px solid #bfdbfe;
  background: #eff6ff;
  color: #1e3a8a;
}
:root[data-theme="dark"] .qb-tag,
html.dark .qb-tag {
  border-color: #334155;
  background: rgba(30, 41, 59, 0.9);
  color: #cbd5e1;
}
:root[data-theme="dark"] .text-slate-900,
:root[data-theme="dark"] .text-slate-800,
html.dark .text-slate-900,
html.dark .text-slate-800 {
  color: #e2e8f0 !important;
}
:root[data-theme="dark"] .text-slate-700,
:root[data-theme="dark"] .text-slate-600,
:root[data-theme="dark"] .text-slate-500,
html.dark .text-slate-700,
html.dark .text-slate-600,
html.dark .text-slate-500 {
  color: #94a3b8 !important;
}
:root[data-theme="dark"] .bg-white\/95,
html.dark .bg-white\/95 {
  background-color: rgba(15, 23, 42, 0.94) !important;
}
:root[data-theme="dark"] .border-white\/30,
html.dark .border-white\/30 {
  border-color: rgba(148, 163, 184, 0.24) !important;
}
.qb-auth-backdrop {
  background: linear-gradient(135deg, rgba(15, 23, 42, 0.62), rgba(8, 47, 73, 0.48)),
    radial-gradient(circle at 20% 20%, rgba(56, 189, 248, 0.18), transparent 48%),
    radial-gradient(circle at 80% 20%, rgba(16, 185, 129, 0.18), transparent 42%);
}
:root[data-theme="dark"] .qb-auth-backdrop,
html.dark .qb-auth-backdrop {
  background: linear-gradient(135deg, rgba(2, 6, 23, 0.82), rgba(8, 47, 73, 0.68)),
    radial-gradient(circle at 20% 20%, rgba(14, 165, 233, 0.2), transparent 46%),
    radial-gradient(circle at 80% 20%, rgba(20, 184, 166, 0.2), transparent 44%);
}
.qb-auth-panel {
  border: 1px solid rgba(255, 255, 255, 0.4);
  background: rgba(255, 255, 255, 0.95);
}
:root[data-theme="dark"] .qb-auth-panel,
html.dark .qb-auth-panel {
  border-color: rgba(148, 163, 184, 0.24);
  background: rgba(15, 23, 42, 0.94);
}
.qb-theme-toggle {
  position: relative;
  display: inline-flex;
  width: 5.2rem;
  height: 2.2rem;
  border-radius: 999px;
  border: 1px solid #cbd5e1;
  background: linear-gradient(90deg, #fff7cc, #e2e8f0);
  cursor: pointer;
}
.qb-theme-toggle.is-compact {
  width: 4.6rem;
  height: 2rem;
}
.qb-theme-icon {
  position: absolute;
  top: 50%;
  width: 1.5rem;
  height: 1.5rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transform: translate(-50%, -50%);
  z-index: 3;
  font-size: 0.9rem;
  line-height: 1;
  text-align: center;
  pointer-events: none;
}
.qb-theme-sun {
  left: 1.1rem;
  color: #d97706;
  transform: translate(-50%, calc(-50% - 0.1em));
}
.qb-theme-moon {
  left: 4.1rem;
  color: #334155;
  transform: translate(-50%, calc(-50% - 0.1em));
}
.qb-theme-toggle.is-compact .qb-theme-sun {
  left: 1.01rem;
}
.qb-theme-toggle.is-compact .qb-theme-moon {
  left: 3.59rem;
}
.qb-theme-knob {
  position: absolute;
  top: 50%;
  left: 0.24rem;
  width: 1.72rem;
  height: 1.72rem;
  border-radius: 999px;
  background: #ffffff;
  box-shadow: 0 4px 10px rgba(15, 23, 42, 0.2);
  transform: translateY(-50%);
  transition: transform 180ms ease;
}
.qb-theme-toggle.is-compact .qb-theme-knob {
  width: 1.54rem;
  height: 1.54rem;
}
.qb-theme-toggle.is-dark {
  border-color: #334155;
  background: linear-gradient(90deg, #0f172a, #1e293b);
}
.qb-theme-toggle.is-dark .qb-theme-knob {
  transform: translate(3rem, -50%);
  background: #dbeafe;
}
.qb-theme-toggle.is-dark.is-compact .qb-theme-knob {
  transform: translate(2.58rem, -50%);
}
.qb-theme-toggle.is-dark .qb-theme-moon {
  color: #f8fafc;
}
.qb-theme-toggle.is-dark .qb-theme-sun {
  color: #94a3b8;
}
.qb-grid {
  display: grid;
  gap: 0.9rem;
}
.qb-voice-cta-row {
  display: flex;
  align-items: stretch;
  gap: 0.55rem;
}
.qb-voice-main-button {
  flex: 1 1 100%;
  min-width: 0;
  transition: flex-basis 280ms cubic-bezier(0.22, 0.84, 0.25, 1),
    max-width 280ms cubic-bezier(0.22, 0.84, 0.25, 1);
}
.qb-voice-cta-row.is-recording .qb-voice-main-button {
  flex-basis: 75%;
  max-width: 75%;
}
.qb-voice-cancel-button {
  flex: 0 0 0%;
  max-width: 0;
  opacity: 0;
  transform: translateX(12px) scale(0.96);
  padding-inline: 0;
  border-width: 0;
  overflow: hidden;
  white-space: nowrap;
  pointer-events: none;
  transition: flex-basis 280ms cubic-bezier(0.22, 0.84, 0.25, 1),
    max-width 280ms cubic-bezier(0.22, 0.84, 0.25, 1),
    opacity 180ms ease,
    transform 280ms cubic-bezier(0.22, 0.84, 0.25, 1),
    padding-inline 280ms cubic-bezier(0.22, 0.84, 0.25, 1),
    border-width 280ms cubic-bezier(0.22, 0.84, 0.25, 1);
}
.qb-voice-cta-row.is-recording .qb-voice-cancel-button {
  flex-basis: 25%;
  max-width: 25%;
  opacity: 1;
  transform: translateX(0) scale(1);
  padding-inline: 0.92rem;
  border-width: 1px;
  pointer-events: auto;
}
.qb-voice-processing {
  display: flex;
  align-items: center;
  gap: 0.65rem;
}
.qb-voice-processing-track {
  position: relative;
  flex: 1 1 auto;
  height: 0.46rem;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.32);
  background: rgba(148, 163, 184, 0.15);
  overflow: hidden;
}
.qb-voice-processing-glow {
  position: absolute;
  inset: 0;
  width: 42%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(45, 212, 191, 0), rgba(45, 212, 191, 0.9), rgba(14, 116, 144, 0));
  animation: qb-voice-shimmer 1080ms ease-in-out infinite;
}
.qb-app-nav {
  position: fixed;
  left: 0.65rem;
  right: 0.65rem;
  bottom: calc(0.65rem + env(safe-area-inset-bottom, 0px));
  z-index: 50;
  border-radius: 1.15rem;
  border: 1px solid rgba(186, 205, 226, 0.9);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.97), rgba(241, 245, 249, 0.96));
  box-shadow: 0 20px 40px rgba(15, 23, 42, 0.14),
    0 8px 18px rgba(15, 23, 42, 0.08),
    0 1px 0 rgba(255, 255, 255, 0.8) inset;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.qb-app-nav-list {
  align-items: center;
}
.qb-nav-link {
  min-height: 3.15rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  letter-spacing: 0.01em;
}
.qb-nav-link-label {
  font-size: 0.95rem;
}
.qb-nav-link-idle {
  border: 1px solid rgba(186, 205, 226, 0.92);
  background: linear-gradient(180deg, #f8fafc, #f1f5f9);
  color: #334155;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8) inset,
    0 6px 14px rgba(148, 163, 184, 0.16);
}
.qb-nav-link-idle:hover {
  border-color: rgba(148, 163, 184, 0.84);
  background: linear-gradient(180deg, #f1f5f9, #e2e8f0);
}
.qb-nav-link-active {
  border: 1px solid rgba(12, 74, 110, 0.38);
  background: linear-gradient(135deg, #0f766e, #0b5f89);
  color: #ffffff;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.22) inset,
    0 12px 24px rgba(13, 148, 136, 0.34);
  transform: translateY(-1px);
}
:root[data-theme="dark"] .qb-nav-link-idle,
html.dark .qb-nav-link-idle {
  background: linear-gradient(180deg, #0d1b31, #0a1729);
  color: #dbe8ff;
  border: 1px solid #2a3a58;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.05) inset,
    0 8px 18px rgba(2, 6, 23, 0.45);
}
:root[data-theme="dark"] .qb-nav-link-idle:hover,
html.dark .qb-nav-link-idle:hover {
  border-color: #3c4f73;
  background: linear-gradient(180deg, #11223d, #0d1d35);
}
:root[data-theme="dark"] .qb-nav-link-active,
html.dark .qb-nav-link-active {
  background: linear-gradient(135deg, #0f766e, #0b5f89);
  color: #f8fafc;
  border-color: rgba(56, 189, 248, 0.3);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.17) inset,
    0 12px 28px rgba(6, 182, 212, 0.35);
}
:root[data-theme="dark"] .qb-app-nav,
html.dark .qb-app-nav {
  border-color: rgba(37, 53, 84, 0.9);
  background: linear-gradient(180deg, rgba(7, 17, 33, 0.95), rgba(5, 13, 26, 0.96));
  box-shadow: 0 24px 48px rgba(2, 6, 23, 0.58),
    0 8px 20px rgba(2, 6, 23, 0.45),
    0 1px 0 rgba(255, 255, 255, 0.05) inset;
}
.qb-chat-thread {
  border: 1px solid #e2e8f0;
  background: #ffffff;
}
.qb-chat-bubble-user {
  border-color: #99f6e4;
  background: linear-gradient(160deg, #ecfeff 0%, #f0fdfa 100%);
  color: #0f172a;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.9) inset,
    0 10px 24px rgba(13, 148, 136, 0.14);
}
.qb-chat-bubble-assistant {
  border-color: #e2e8f0;
  background: linear-gradient(160deg, #ffffff 0%, #f8fafc 100%);
  color: #0f172a;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.95) inset,
    0 10px 22px rgba(15, 23, 42, 0.08);
}
.qb-chat-bubble-system {
  border-color: #fde68a;
  background: linear-gradient(160deg, #fffdf0 0%, #fffbeb 100%);
  color: #0f172a;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.9) inset,
    0 8px 20px rgba(146, 64, 14, 0.12);
}
.qb-chat-lane-user {
  width: 66%;
  margin-left: auto;
  transform-origin: bottom right;
  animation: qb-bubble-in-right 280ms cubic-bezier(0.22, 0.84, 0.25, 1);
}
.qb-chat-lane-assistant {
  width: 66%;
  margin-right: auto;
  transform-origin: bottom left;
  animation: qb-bubble-in-left 300ms cubic-bezier(0.22, 0.84, 0.25, 1);
}
.qb-code-block {
  background: #f1f5f9;
}
.qb-xp-progress {
  position: relative;
  overflow: hidden;
  background: linear-gradient(110deg, #10b1a4 0%, #139fb6 100%);
}
.qb-xp-progress::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 200%;
  background: linear-gradient(
    110deg,
    #10b1a4 0%,
    #16b6aa 16%,
    #12adbe 32%,
    #0f9ab7 48%,
    #10b1a4 64%,
    #16b6aa 80%,
    #12adbe 100%
  );
  animation: qb-xp-flow 10000ms linear infinite;
  will-change: transform;
}
.qb-xp-progress::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.14) 52%, transparent 100%);
  transform: translateX(-120%);
  animation: qb-xp-sheen 6800ms ease-in-out infinite;
}
.qb-xp-flight-layer {
  position: fixed;
  inset: 0;
  z-index: 65;
  pointer-events: none;
  overflow: hidden;
}
.qb-xp-flight-bubble {
  position: fixed;
  width: 0.62rem;
  height: 0.62rem;
  border-radius: 999px;
  background: radial-gradient(circle at 35% 35%, #99f6e4 0%, #2dd4bf 45%, #0891b2 100%);
  box-shadow: 0 0 0 1px rgba(153, 246, 228, 0.2),
    0 6px 14px rgba(13, 148, 136, 0.35);
  opacity: 0;
  transform: translate3d(0, 0, 0) scale(0.92);
  animation: qb-xp-flight 960ms cubic-bezier(0.18, 0.76, 0.26, 1) forwards;
}
.qb-completion-prompt-blink {
  animation: qb-completion-blink 260ms steps(2, end) infinite;
}
.qb-typing-dots {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  min-height: 1rem;
}
.qb-typing-dot {
  width: 0.42rem;
  height: 0.42rem;
  border-radius: 999px;
  background: currentColor;
  opacity: 0.35;
  animation: qb-typing-pulse 1s ease-in-out infinite;
}
.qb-typing-dot:nth-child(2) {
  animation-delay: 0.15s;
}
.qb-typing-dot:nth-child(3) {
  animation-delay: 0.3s;
}
@keyframes qb-typing-pulse {
  0%,
  80%,
  100% {
    transform: translateY(0);
    opacity: 0.35;
  }
  40% {
    transform: translateY(-2px);
    opacity: 0.9;
  }
}
@keyframes qb-voice-shimmer {
  0% {
    transform: translateX(-120%);
    opacity: 0.7;
  }
  50% {
    opacity: 1;
  }
  100% {
    transform: translateX(260%);
    opacity: 0.7;
  }
}
@keyframes qb-bubble-in-right {
  0% {
    opacity: 0.96;
    transform: translate3d(18px, 14px, 0) scale(0.985);
  }
  100% {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }
}
@keyframes qb-bubble-in-left {
  0% {
    opacity: 0.96;
    transform: translate3d(-18px, 14px, 0) scale(0.985);
  }
  100% {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }
}
@keyframes qb-xp-flow {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
@keyframes qb-xp-sheen {
  0% {
    transform: translateX(-120%);
    opacity: 0.08;
  }
  35% {
    opacity: 0.16;
  }
  100% {
    transform: translateX(140%);
    opacity: 0.08;
  }
}
@keyframes qb-xp-flight {
  0% {
    opacity: 0.1;
    transform: translate3d(0, 0, 0) scale(0.82);
  }
  12% {
    opacity: 1;
    transform: translate3d(0, -8px, 0) scale(1);
  }
  62% {
    opacity: 1;
    transform: translate3d(
        calc(var(--qb-xp-dx, 0px) * 0.72),
        calc(var(--qb-xp-dy, 0px) * 0.78 - 22px),
        0
      )
      scale(1.08);
  }
  100% {
    opacity: 0;
    transform: translate3d(var(--qb-xp-dx, 0px), var(--qb-xp-dy, 0px), 0) scale(0.58);
  }
}
@keyframes qb-completion-blink {
  0%,
  49% {
    opacity: 1;
    filter: saturate(1);
  }
  50%,
  100% {
    opacity: 0.45;
    filter: saturate(0.7);
  }
}
:root[data-theme="dark"] .qb-xp-progress,
html.dark .qb-xp-progress {
  background: linear-gradient(110deg, #0e6d67 0%, #0b6f86 100%);
}
:root[data-theme="dark"] .qb-xp-progress::before,
html.dark .qb-xp-progress::before {
  background: linear-gradient(
    110deg,
    #0e6d67 0%,
    #0f766e 16%,
    #0c7288 32%,
    #0b6f86 48%,
    #0e6d67 64%,
    #0f766e 80%,
    #0c7288 100%
  );
}
:root[data-theme="dark"] .qb-chat-thread,
html.dark .qb-chat-thread {
  border-color: #23314a;
  background: #060f20;
}
:root[data-theme="dark"] .qb-chat-bubble-user,
html.dark .qb-chat-bubble-user {
  border-color: #115e59 !important;
  background: linear-gradient(160deg, #0b2d34 0%, #0a2730 100%) !important;
  color: #d1fae5 !important;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.04) inset,
    0 12px 28px rgba(15, 118, 110, 0.2) !important;
}
:root[data-theme="dark"] .qb-chat-bubble-assistant,
html.dark .qb-chat-bubble-assistant {
  border-color: #334155 !important;
  background: linear-gradient(160deg, #141f32 0%, #101a2c 100%) !important;
  color: #e2e8f0 !important;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.03) inset,
    0 12px 26px rgba(2, 6, 23, 0.35) !important;
}
:root[data-theme="dark"] .qb-chat-bubble-system,
html.dark .qb-chat-bubble-system {
  border-color: #92400e !important;
  background: linear-gradient(160deg, #332811 0%, #2a220f 100%) !important;
  color: #fde68a !important;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.03) inset,
    0 10px 24px rgba(146, 64, 14, 0.28) !important;
}
:root[data-theme="dark"] .qb-code-block,
html.dark .qb-code-block {
  background: #0f172a !important;
  color: #cbd5e1 !important;
}
:root[data-theme="dark"] .qb-voice-processing-track,
html.dark .qb-voice-processing-track {
  border-color: rgba(51, 65, 85, 0.95);
  background: rgba(15, 23, 42, 0.8);
}
:root[data-theme="dark"] .qb-guest-lock,
html.dark .qb-guest-lock {
  border-color: #334155 !important;
  background: rgba(15, 23, 42, 0.94) !important;
  box-shadow: 0 10px 26px rgba(2, 6, 23, 0.45);
}
:root[data-theme="dark"] .qb-guest-lock-title,
html.dark .qb-guest-lock-title {
  color: #f1f5f9 !important;
}
@media (prefers-reduced-motion: reduce) {
  .qb-xp-progress,
  .qb-xp-progress::before,
  .qb-xp-progress::after {
    animation: none;
  }
}
@media (max-width: 900px) {
  .qb-shell {
    width: min(1120px, 100% - 0.75rem);
    padding-block: 0.7rem calc(9.25rem + env(safe-area-inset-bottom, 0px));
  }
  .qb-bottom-sheet {
    bottom: calc(6.05rem + env(safe-area-inset-bottom, 0px)) !important;
    border-bottom-left-radius: 1rem;
    border-bottom-right-radius: 1rem;
  }
  .qb-chat-lane-user,
  .qb-chat-lane-assistant {
    width: 100%;
  }
}
@media (min-width: 901px) {
  .qb-shell {
    padding-block: 1rem 2rem;
  }
  .qb-app-nav {
    position: static;
    inset: auto;
  }
}
@media (prefers-reduced-motion: reduce) {
  .qb-chat-lane-user,
  .qb-chat-lane-assistant {
    animation: none;
  }
}
@property --tw-space-y-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-font-weight {
  syntax: "*";
  inherits: false;
}
@property --tw-tracking {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-inset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-ring-inset {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-offset-width {
  syntax: "<length>";
  inherits: false;
  initial-value: 0px;
}
@property --tw-ring-offset-color {
  syntax: "*";
  inherits: false;
  initial-value: #fff;
}
@property --tw-ring-offset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-blur {
  syntax: "*";
  inherits: false;
}
@property --tw-brightness {
  syntax: "*";
  inherits: false;
}
@property --tw-contrast {
  syntax: "*";
  inherits: false;
}
@property --tw-grayscale {
  syntax: "*";
  inherits: false;
}
@property --tw-hue-rotate {
  syntax: "*";
  inherits: false;
}
@property --tw-invert {
  syntax: "*";
  inherits: false;
}
@property --tw-opacity {
  syntax: "*";
  inherits: false;
}
@property --tw-saturate {
  syntax: "*";
  inherits: false;
}
@property --tw-sepia {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-drop-shadow-size {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-blur {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-brightness {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-contrast {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-grayscale {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-hue-rotate {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-invert {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-opacity {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-saturate {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-sepia {
  syntax: "*";
  inherits: false;
}
@layer properties {
  @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color:rgb(from red r g b)))) {
    *, ::before, ::after, ::backdrop {
      --tw-space-y-reverse: 0;
      --tw-border-style: solid;
      --tw-font-weight: initial;
      --tw-tracking: initial;
      --tw-shadow: 0 0 #0000;
      --tw-shadow-color: initial;
      --tw-shadow-alpha: 100%;
      --tw-inset-shadow: 0 0 #0000;
      --tw-inset-shadow-color: initial;
      --tw-inset-shadow-alpha: 100%;
      --tw-ring-color: initial;
      --tw-ring-shadow: 0 0 #0000;
      --tw-inset-ring-color: initial;
      --tw-inset-ring-shadow: 0 0 #0000;
      --tw-ring-inset: initial;
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-color: #fff;
      --tw-ring-offset-shadow: 0 0 #0000;
      --tw-blur: initial;
      --tw-brightness: initial;
      --tw-contrast: initial;
      --tw-grayscale: initial;
      --tw-hue-rotate: initial;
      --tw-invert: initial;
      --tw-opacity: initial;
      --tw-saturate: initial;
      --tw-sepia: initial;
      --tw-drop-shadow: initial;
      --tw-drop-shadow-color: initial;
      --tw-drop-shadow-alpha: 100%;
      --tw-drop-shadow-size: initial;
      --tw-backdrop-blur: initial;
      --tw-backdrop-brightness: initial;
      --tw-backdrop-contrast: initial;
      --tw-backdrop-grayscale: initial;
      --tw-backdrop-hue-rotate: initial;
      --tw-backdrop-invert: initial;
      --tw-backdrop-opacity: initial;
      --tw-backdrop-saturate: initial;
      --tw-backdrop-sepia: initial;
    }
  }
}

