/* [next]/internal/font/google/plus_jakarta_sans_75580a06.module.css [app-client] (css) */
@font-face {
  font-family: Plus Jakarta Sans;
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url("../media/0b1dc8ddaa74ba49-s.04o39dzmj.ey..woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: Plus Jakarta Sans;
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url("../media/e629b5bc06499d58-s.0b_~8bw~gzh90.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Plus Jakarta Sans;
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url("../media/1a099d89ee94ee96-s.0_qb~~5cn13jl.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, 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;
}

@font-face {
  font-family: Plus Jakarta Sans;
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url("../media/fba5a26ea33df6a3-s.p.0eehd8tgys7nv.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Plus Jakarta Sans Fallback;
  src: local(Arial);
  ascent-override: 98.88%;
  descent-override: 21.15%;
  line-gap-override: 0.0%;
  size-adjust: 104.98%;
}

.plus_jakarta_sans_75580a06-module__h4idsq__className {
  font-family: Plus Jakarta Sans, Plus Jakarta Sans Fallback;
  font-style: normal;
}

.plus_jakarta_sans_75580a06-module__h4idsq__variable {
  --font-plus-jakarta: "Plus Jakarta Sans", "Plus Jakarta Sans Fallback";
}

/* [next]/internal/font/google/lora_f1014322.module.css [app-client] (css) */
@font-face {
  font-family: Lora;
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url("../media/e7150917543fc9da-s.071m.n3zzn52i.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: Lora;
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url("../media/71fbf9c08529c2a5-s.0s73vwibz65qg.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: Lora;
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url("../media/e9457141811d41ae-s.00tq~sneouii2.woff2") format("woff2");
  unicode-range: U+302-303, U+305, U+307-308, U+310, U+312, U+315, U+31A, U+326-327, U+32C, U+32F-330, U+332-333, U+338, U+33A, U+346, U+34D, U+391-3A1, U+3A3-3A9, U+3B1-3C9, U+3D1, U+3D5-3D6, U+3F0-3F1, U+3F4-3F5, U+2016-2017, U+2034-2038, U+203C, U+2040, U+2043, U+2047, U+2050, U+2057, U+205F, U+2070-2071, U+2074-208E, U+2090-209C, U+20D0-20DC, U+20E1, U+20E5-20EF, U+2100-2112, U+2114-2115, U+2117-2121, U+2123-214F, U+2190, U+2192, U+2194-21AE, U+21B0-21E5, U+21F1-21F2, U+21F4-2211, U+2213-2214, U+2216-22FF, U+2308-230B, U+2310, U+2319, U+231C-2321, U+2336-237A, U+237C, U+2395, U+239B-23B7, U+23D0, U+23DC-23E1, U+2474-2475, U+25AF, U+25B3, U+25B7, U+25BD, U+25C1, U+25CA, U+25CC, U+25FB, U+266D-266F, U+27C0-27FF, U+2900-2AFF, U+2B0E-2B11, U+2B30-2B4C, U+2BFE, U+3030, U+FF5B, U+FF5D, U+1D400-1D7FF, U+1EE??;
}

@font-face {
  font-family: Lora;
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url("../media/ac34884600cd8d5d-s.0q61mniqzdjv_.woff2") format("woff2");
  unicode-range: U+1-C, U+E-1F, U+7F-9F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+28??, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B??, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F0??, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F7??, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8BB, U+1F8C0-1F8C1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA89, U+1FA8F-1FAC6, U+1FACE-1FADC, U+1FADF-1FAE9, U+1FAF0-1FAF8, U+1FB??;
}

@font-face {
  font-family: Lora;
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url("../media/e1ccd2766b08c828-s.0dd-~h-3wf1jt.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Lora;
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url("../media/507a47c1876d4ec2-s.0vig0aoy18nm3.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, 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;
}

@font-face {
  font-family: Lora;
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url("../media/8c2eb9ceedecfc8e-s.p.0oeo8epbafgia.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Lora Fallback;
  src: local(Times New Roman);
  ascent-override: 87.33%;
  descent-override: 23.78%;
  line-gap-override: 0.0%;
  size-adjust: 115.2%;
}

.lora_f1014322-module__l-izAG__className {
  font-family: Lora, Lora Fallback;
  font-style: normal;
}

.lora_f1014322-module__l-izAG__variable {
  --font-lora: "Lora", "Lora Fallback";
}

/* [project]/app/globals.css [app-client] (css) */
*, :before, :after, ::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: #3b82f680;
  --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: 0 solid #e5e7eb;
}

:before, :after {
  --tw-content: "";
}

html, :host {
  -webkit-text-size-adjust: 100%;
  tab-size: 4;
  line-height: 1.5;
  font-family: var(--sans);
  font-feature-settings: normal;
  font-variation-settings: normal;
  -webkit-tap-highlight-color: transparent;
}

body {
  line-height: inherit;
  margin: 0;
}

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(--mono);
  font-feature-settings: normal;
  font-variation-settings: normal;
  font-size: 1em;
}

small {
  font-size: 80%;
}

sub, sup {
  vertical-align: baseline;
  font-size: 75%;
  line-height: 0;
  position: relative;
}

sub {
  bottom: -.25em;
}

sup {
  top: -.5em;
}

table {
  text-indent: 0;
  border-color: inherit;
  border-collapse: collapse;
}

button, input, optgroup, select, textarea {
  font-feature-settings: inherit;
  font-variation-settings: inherit;
  font-family: 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: #0000;
  background-image: none;
}

:-moz-focusring {
  outline: auto;
}

:-moz-ui-invalid {
  box-shadow: none;
}

progress {
  vertical-align: baseline;
}

::-webkit-inner-spin-button {
  height: auto;
}

::-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 {
  margin: 0;
  padding: 0;
  list-style: none;
}

dialog {
  padding: 0;
}

textarea {
  resize: vertical;
}

input::-moz-placeholder {
  opacity: 1;
  color: #9ca3af;
}

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 {
  vertical-align: middle;
  display: block;
}

img, video {
  max-width: 100%;
  height: auto;
}

[hidden]:where(:not([hidden="until-found"])) {
  display: none;
}

.visible {
  visibility: visible;
}

.fixed {
  position: fixed;
}

.absolute {
  position: absolute;
}

.relative {
  position: relative;
}

.inset-0 {
  inset: 0;
}

.-left-\[21px\] {
  left: -21px;
}

.right-0 {
  right: 0;
}

.top-1\.5 {
  top: .375rem;
}

.top-9 {
  top: 2.25rem;
}

.z-20 {
  z-index: 20;
}

.z-40 {
  z-index: 40;
}

.mx-auto {
  margin-left: auto;
  margin-right: auto;
}

.mb-1 {
  margin-bottom: .25rem;
}

.mb-2 {
  margin-bottom: .5rem;
}

.mb-3 {
  margin-bottom: .75rem;
}

.mb-4 {
  margin-bottom: 1rem;
}

.mb-5 {
  margin-bottom: 1.25rem;
}

.ml-2 {
  margin-left: .5rem;
}

.ml-5 {
  margin-left: 1.25rem;
}

.ml-6 {
  margin-left: 1.5rem;
}

.ml-auto {
  margin-left: auto;
}

.mr-2 {
  margin-right: .5rem;
}

.mt-0\.5 {
  margin-top: .125rem;
}

.mt-1 {
  margin-top: .25rem;
}

.mt-2 {
  margin-top: .5rem;
}

.mt-3 {
  margin-top: .75rem;
}

.mt-4 {
  margin-top: 1rem;
}

.mt-5 {
  margin-top: 1.25rem;
}

.line-clamp-2 {
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  display: -webkit-box;
  overflow: hidden;
}

.line-clamp-3 {
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  display: -webkit-box;
  overflow: hidden;
}

.line-clamp-4 {
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  display: -webkit-box;
  overflow: hidden;
}

.block {
  display: block;
}

.inline-block {
  display: inline-block;
}

.flex {
  display: flex;
}

.inline-flex {
  display: inline-flex;
}

.grid {
  display: grid;
}

.hidden {
  display: none;
}

.aspect-video {
  aspect-ratio: 16 / 9;
}

.h-1\.5 {
  height: .375rem;
}

.h-10 {
  height: 2.5rem;
}

.h-2\.5 {
  height: .625rem;
}

.h-6 {
  height: 1.5rem;
}

.h-8 {
  height: 2rem;
}

.h-9 {
  height: 2.25rem;
}

.h-\[360px\] {
  height: 360px;
}

.h-auto {
  height: auto;
}

.h-full {
  height: 100%;
}

.h-3\.5 {
  height: .875rem;
}

.h-5 {
  height: 1.25rem;
}

.max-h-28 {
  max-height: 7rem;
}

.max-h-32 {
  max-height: 8rem;
}

.max-h-36 {
  max-height: 9rem;
}

.max-h-40 {
  max-height: 10rem;
}

.max-h-44 {
  max-height: 11rem;
}

.max-h-56 {
  max-height: 14rem;
}

.max-h-\[320px\] {
  max-height: 320px;
}

.max-h-\[360px\] {
  max-height: 360px;
}

.max-h-\[calc\(100vh-180px\)\] {
  max-height: calc(100vh - 180px);
}

.min-h-0 {
  min-height: 0;
}

.min-h-32 {
  min-height: 8rem;
}

.min-h-\[280px\] {
  min-height: 280px;
}

.min-h-\[320px\] {
  min-height: 320px;
}

.min-h-\[380px\] {
  min-height: 380px;
}

.min-h-\[420px\] {
  min-height: 420px;
}

.min-h-\[480px\] {
  min-height: 480px;
}

.min-h-\[72px\] {
  min-height: 72px;
}

.w-1\.5 {
  width: .375rem;
}

.w-10 {
  width: 2.5rem;
}

.w-12 {
  width: 3rem;
}

.w-2\.5 {
  width: .625rem;
}

.w-4 {
  width: 1rem;
}

.w-5 {
  width: 1.25rem;
}

.w-6 {
  width: 1.5rem;
}

.w-8 {
  width: 2rem;
}

.w-\[240px\] {
  width: 240px;
}

.w-\[260px\] {
  width: 260px;
}

.w-\[300px\] {
  width: 300px;
}

.w-\[320px\] {
  width: 320px;
}

.w-\[330px\] {
  width: 330px;
}

.w-\[360px\] {
  width: 360px;
}

.w-\[min\(460px\,calc\(100vw-48px\)\)\] {
  width: min(460px, 100vw - 48px);
}

.w-full {
  width: 100%;
}

.w-3\.5 {
  width: .875rem;
}

.min-w-0 {
  min-width: 0;
}

.min-w-\[220px\] {
  min-width: 220px;
}

.min-w-\[260px\] {
  min-width: 260px;
}

.min-w-\[min\(100\%\,24rem\)\] {
  min-width: min(100%, 24rem);
}

.max-w-2xl {
  max-width: 42rem;
}

.max-w-36 {
  max-width: 9rem;
}

.max-w-3xl {
  max-width: 48rem;
}

.max-w-4xl {
  max-width: 56rem;
}

.max-w-6xl {
  max-width: 72rem;
}

.max-w-\[210px\] {
  max-width: 210px;
}

.max-w-full {
  max-width: 100%;
}

.max-w-md {
  max-width: 28rem;
}

.max-w-sm {
  max-width: 24rem;
}

.flex-1 {
  flex: 1;
}

.flex-\[1\.4\] {
  flex: 1.4;
}

.flex-\[1_1_24rem\] {
  flex: 24rem;
}

.shrink-0 {
  flex-shrink: 0;
}

.basis-full {
  flex-basis: 100%;
}

@keyframes pulse {
  50% {
    opacity: .5;
  }
}

.animate-pulse {
  animation: 2s cubic-bezier(.4, 0, .6, 1) infinite pulse;
}

.cursor-pointer {
  cursor: pointer;
}

.select-none {
  -webkit-user-select: none;
  user-select: none;
}

.resize-none {
  resize: none;
}

.resize-y {
  resize: vertical;
}

.scroll-mt-5 {
  scroll-margin-top: 1.25rem;
}

.list-disc {
  list-style-type: disc;
}

.grid-cols-\[18px_22px_1fr\] {
  grid-template-columns: 18px 22px 1fr;
}

.grid-cols-\[minmax\(320px\,0\.85fr\)_minmax\(0\,1\.15fr\)\] {
  grid-template-columns: minmax(320px, .85fr) minmax(0, 1.15fr);
}

.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;
}

.items-baseline {
  align-items: baseline;
}

.justify-end {
  justify-content: flex-end;
}

.justify-center {
  justify-content: center;
}

.justify-between {
  justify-content: space-between;
}

.gap-0\.5 {
  gap: .125rem;
}

.gap-1 {
  gap: .25rem;
}

.gap-1\.5 {
  gap: .375rem;
}

.gap-2 {
  gap: .5rem;
}

.gap-2\.5 {
  gap: .625rem;
}

.gap-3 {
  gap: .75rem;
}

.gap-4 {
  gap: 1rem;
}

.gap-5 {
  gap: 1.25rem;
}

.gap-6 {
  gap: 1.5rem;
}

.gap-x-4 {
  -moz-column-gap: 1rem;
  column-gap: 1rem;
}

.gap-y-1 {
  row-gap: .25rem;
}

.space-y-0\.5 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(.125rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(.125rem * var(--tw-space-y-reverse));
}

.space-y-1 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(.25rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(.25rem * var(--tw-space-y-reverse));
}

.space-y-1\.5 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(.375rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(.375rem * var(--tw-space-y-reverse));
}

.space-y-2 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(.5rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(.5rem * var(--tw-space-y-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));
}

.divide-y > :not([hidden]) ~ :not([hidden]) {
  --tw-divide-y-reverse: 0;
  border-top-width: calc(1px * calc(1 - var(--tw-divide-y-reverse)));
  border-bottom-width: calc(1px * var(--tw-divide-y-reverse));
}

.self-start {
  align-self: flex-start;
}

.overflow-auto {
  overflow: auto;
}

.overflow-hidden {
  overflow: hidden;
}

.overflow-y-auto {
  overflow-y: auto;
}

.truncate {
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

.whitespace-pre-wrap {
  white-space: pre-wrap;
}

.break-words {
  overflow-wrap: break-word;
}

.rounded {
  border-radius: .25rem;
}

.rounded-\[var\(--radius\)\] {
  border-radius: var(--radius);
}

.rounded-full {
  border-radius: 9999px;
}

.rounded-md {
  border-radius: .375rem;
}

.border {
  border-width: 1px;
}

.border-b {
  border-bottom-width: 1px;
}

.border-l {
  border-left-width: 1px;
}

.border-l-\[3px\] {
  border-left-width: 3px;
}

.border-r {
  border-right-width: 1px;
}

.border-t {
  border-top-width: 1px;
}

.border-dashed {
  border-style: dashed;
}

.border-\[var\(--accent\)\] {
  border-color: var(--accent);
}

.border-\[var\(--border\)\] {
  border-color: var(--border);
}

.border-\[var\(--green\)\] {
  border-color: var(--green);
}

.border-\[var\(--red\)\] {
  border-color: var(--red);
}

.border-amber-400\/70 {
  border-color: #fbbf24b3;
}

.border-cyan-400\/70 {
  border-color: #22d3eeb3;
}

.border-emerald-400\/70 {
  border-color: #34d399b3;
}

.border-indigo-400\/70 {
  border-color: #818cf8b3;
}

.border-rose-400\/70 {
  border-color: #fb7185b3;
}

.border-sky-400\/70 {
  border-color: #38bdf8b3;
}

.bg-\[var\(--accent\)\] {
  background-color: var(--accent);
}

.bg-\[var\(--accent-strong\)\] {
  background-color: var(--accent-strong);
}

.bg-\[var\(--bg\)\] {
  background-color: var(--bg);
}

.bg-\[var\(--muted-2\)\] {
  background-color: var(--muted-2);
}

.bg-\[var\(--surface\)\] {
  background-color: var(--surface);
}

.bg-\[var\(--surface-2\)\] {
  background-color: var(--surface-2);
}

.bg-\[var\(--surface-3\)\] {
  background-color: var(--surface-3);
}

.bg-amber-400 {
  --tw-bg-opacity: 1;
  background-color: rgb(251 191 36 / var(--tw-bg-opacity, 1));
}

.bg-amber-50\/70 {
  background-color: #fffbebb3;
}

.bg-black {
  --tw-bg-opacity: 1;
  background-color: rgb(0 0 0 / var(--tw-bg-opacity, 1));
}

.bg-black\/30 {
  background-color: #0000004d;
}

.bg-cyan-50\/70 {
  background-color: #ecfeffb3;
}

.bg-emerald-50\/70 {
  background-color: #ecfdf5b3;
}

.bg-emerald-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(16 185 129 / var(--tw-bg-opacity, 1));
}

.bg-indigo-50\/70 {
  background-color: #eef2ffb3;
}

.bg-rose-50\/70 {
  background-color: #fff1f2b3;
}

.bg-rose-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(244 63 94 / var(--tw-bg-opacity, 1));
}

.bg-sky-50\/70 {
  background-color: #f0f9ffb3;
}

.bg-transparent {
  background-color: #0000;
}

.bg-white {
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}

.stroke-current {
  stroke: currentColor;
}

.stroke-\[1\.9\] {
  stroke-width: 1.9px;
}

.object-contain {
  -o-object-fit: contain;
  object-fit: contain;
}

.p-0\.5 {
  padding: .125rem;
}

.p-1 {
  padding: .25rem;
}

.p-2 {
  padding: .5rem;
}

.p-3 {
  padding: .75rem;
}

.p-4 {
  padding: 1rem;
}

.p-5 {
  padding: 1.25rem;
}

.p-6 {
  padding: 1.5rem;
}

.px-1 {
  padding-left: .25rem;
  padding-right: .25rem;
}

.px-1\.5 {
  padding-left: .375rem;
  padding-right: .375rem;
}

.px-10 {
  padding-left: 2.5rem;
  padding-right: 2.5rem;
}

.px-2 {
  padding-left: .5rem;
  padding-right: .5rem;
}

.px-2\.5 {
  padding-left: .625rem;
  padding-right: .625rem;
}

.px-3 {
  padding-left: .75rem;
  padding-right: .75rem;
}

.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-0\.5 {
  padding-top: .125rem;
  padding-bottom: .125rem;
}

.py-1 {
  padding-top: .25rem;
  padding-bottom: .25rem;
}

.py-1\.5 {
  padding-top: .375rem;
  padding-bottom: .375rem;
}

.py-10 {
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
}

.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-1 {
  padding-bottom: .25rem;
}

.pb-4 {
  padding-bottom: 1rem;
}

.pl-3 {
  padding-left: .75rem;
}

.pl-4 {
  padding-left: 1rem;
}

.pl-5 {
  padding-left: 1.25rem;
}

.pr-2 {
  padding-right: .5rem;
}

.pt-1 {
  padding-top: .25rem;
}

.pt-2 {
  padding-top: .5rem;
}

.pt-3 {
  padding-top: .75rem;
}

.text-left {
  text-align: left;
}

.text-center {
  text-align: center;
}

.text-right {
  text-align: right;
}

.font-mono {
  font-family: var(--mono);
}

.text-\[10px\] {
  font-size: 10px;
}

.text-\[11px\] {
  font-size: 11px;
}

.text-\[12px\] {
  font-size: 12px;
}

.text-\[13px\] {
  font-size: 13px;
}

.text-base {
  font-size: 1rem;
  line-height: 1.5rem;
}

.text-lg {
  font-size: 1.125rem;
  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-medium {
  font-weight: 500;
}

.font-normal {
  font-weight: 400;
}

.font-semibold {
  font-weight: 600;
}

.uppercase {
  text-transform: uppercase;
}

.italic {
  font-style: italic;
}

.tabular-nums {
  --tw-numeric-spacing: tabular-nums;
  font-variant-numeric: var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction);
}

.leading-4 {
  line-height: 1rem;
}

.leading-5 {
  line-height: 1.25rem;
}

.leading-6 {
  line-height: 1.5rem;
}

.leading-7 {
  line-height: 1.75rem;
}

.leading-none {
  line-height: 1;
}

.leading-relaxed {
  line-height: 1.625;
}

.tracking-\[0\.14em\] {
  letter-spacing: .14em;
}

.tracking-\[0\.16em\] {
  letter-spacing: .16em;
}

.tracking-wider {
  letter-spacing: .05em;
}

.text-\[var\(--accent\)\] {
  color: var(--accent);
}

.text-\[var\(--green\)\] {
  color: var(--green);
}

.text-\[var\(--muted\)\] {
  color: var(--muted);
}

.text-\[var\(--muted-2\)\] {
  color: var(--muted-2);
}

.text-\[var\(--red\)\] {
  color: var(--red);
}

.text-\[var\(--text\)\] {
  color: var(--text);
}

.text-\[var\(--text-soft\)\] {
  color: var(--text-soft);
}

.text-amber-700 {
  --tw-text-opacity: 1;
  color: rgb(180 83 9 / var(--tw-text-opacity, 1));
}

.text-amber-950 {
  --tw-text-opacity: 1;
  color: rgb(69 26 3 / var(--tw-text-opacity, 1));
}

.text-cyan-700 {
  --tw-text-opacity: 1;
  color: rgb(14 116 144 / var(--tw-text-opacity, 1));
}

.text-cyan-950 {
  --tw-text-opacity: 1;
  color: rgb(8 51 68 / var(--tw-text-opacity, 1));
}

.text-emerald-700 {
  --tw-text-opacity: 1;
  color: rgb(4 120 87 / var(--tw-text-opacity, 1));
}

.text-emerald-950 {
  --tw-text-opacity: 1;
  color: rgb(2 44 34 / var(--tw-text-opacity, 1));
}

.text-indigo-700 {
  --tw-text-opacity: 1;
  color: rgb(67 56 202 / var(--tw-text-opacity, 1));
}

.text-indigo-950 {
  --tw-text-opacity: 1;
  color: rgb(30 27 75 / var(--tw-text-opacity, 1));
}

.text-rose-700 {
  --tw-text-opacity: 1;
  color: rgb(190 18 60 / var(--tw-text-opacity, 1));
}

.text-rose-950 {
  --tw-text-opacity: 1;
  color: rgb(76 5 25 / var(--tw-text-opacity, 1));
}

.text-sky-700 {
  --tw-text-opacity: 1;
  color: rgb(3 105 161 / var(--tw-text-opacity, 1));
}

.text-sky-950 {
  --tw-text-opacity: 1;
  color: rgb(8 47 73 / var(--tw-text-opacity, 1));
}

.text-white {
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.underline-offset-2 {
  text-underline-offset: 2px;
}

.opacity-0 {
  opacity: 0;
}

.opacity-70 {
  opacity: .7;
}

.shadow-lg {
  --tw-shadow: 0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;
  --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-sm {
  --tw-shadow: 0 1px 2px 0 #0000000d;
  --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);
}

.shadow-soft {
  --tw-shadow: var(--shadow-soft);
  --tw-shadow-colored: var(--shadow-soft);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-tight {
  --tw-shadow: var(--shadow-tight);
  --tw-shadow-colored: var(--shadow-tight);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.outline-none {
  outline-offset: 2px;
  outline: 2px solid #0000;
}

.filter {
  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);
}

.transition {
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, -webkit-backdrop-filter, backdrop-filter;
  transition-duration: .15s;
  transition-timing-function: cubic-bezier(.4, 0, .2, 1);
}

.transition-colors {
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
  transition-duration: .15s;
  transition-timing-function: cubic-bezier(.4, 0, .2, 1);
}

.\[stroke-linecap\:round\] {
  stroke-linecap: round;
}

.\[stroke-linejoin\:round\] {
  stroke-linejoin: round;
}

:root {
  --lightningcss-light: initial;
  --lightningcss-dark: ;
  color-scheme: light;
  --bg: #ecf3fa;
  --surface: #fafdff;
  --surface-raised: #f7fbfe;
  --surface-2: #f1f6fc;
  --surface-3: #e5f3ff;
  --text: #121b26;
  --text-soft: #29313a;
  --muted: #5a6169;
  --muted-2: #909aa3;
  --border: #0044831f;
  --border-strong: #00448347;
  --accent: #003d73;
  --accent-strong: #002e5b;
  --accent-2: #77963f;
  --accent-2-strong: #13431a;
  --green: #77963f;
  --red: #c5521c;
  --blue: #1e65aa;
  --radius: 10px;
  --shadow-soft: 0 18px 54px #142a441f;
  --shadow-tight: 0 8px 24px #142a441a;
  --sans: var(--font-plus-jakarta), Inter, ui-sans-serif, system-ui,
    -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --serif: var(--font-lora), Lora, Georgia, "Times New Roman", serif;
  --mono: "SF Mono", "JetBrains Mono", ui-monospace, Menlo, Consolas, monospace;
  --sidebar-width: 220px;
}

@supports (color: lab(0% 0 0)) {
  :root {
    --bg: lab(95.5873% -1.43662 -4.22486);
    --surface: lab(99.0709% -.4884 -1.41364);
    --surface-raised: lab(98.2583% -.729203 -2.11843);
    --surface-2: lab(96.7489% -1.0857 -3.17316);
    --surface-3: lab(95.1493% -3.57389 -8.01466);
    --text: lab(9.44991% -1.61551 -8.37654);
    --text-soft: lab(19.9164% -1.63147 -7.07386);
    --muted: lab(40.8134% -1.46127 -5.72523);
    --muted-2: lab(62.8693% -2.08291 -6.29994);
    --accent: lab(25.0079% .549167 -37.8514);
    --accent-strong: lab(18.0819% 1.34231 -33.7417);
    --accent-2: lab(58.2422% -21.7066 41.1077);
    --accent-2-strong: lab(24.4688% -24.2731 19.4586);
    --green: lab(58.2422% -21.7066 41.1077);
    --red: lab(50.0456% 45.0684 52.1553);
    --blue: lab(41.2613% -1.86475 -44.1502);
  }
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

html, body {
  height: 100%;
}

body {
  background: linear-gradient(180deg,
      #0044830f,
      #7dad470a 320px,
      transparent 620px),
    var(--bg);
  color: var(--text);
  font-family: var(--sans);
  letter-spacing: 0;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizelegibility;
  margin: 0;
  font-size: 14px;
  line-height: 1.45;
  overflow: hidden;
}

.app-frame {
  height: 100vh;
  display: flex;
  overflow: hidden;
}

.sidebar {
  width: var(--sidebar-width);
  background: linear-gradient(#0e375c 0%, #062d4f 48%, #02203c 100%);
  background: linear-gradient(lab(21.8999% -2.62545 -26.909) 0%, lab(17.2606% -2.01501 -25.1772) 48%, lab(11.5064% -1.52874 -21.4649) 100%);
  border-right: 1px solid #ffffff29;
  flex-direction: column;
  flex-shrink: 0;
  display: flex;
  box-shadow: inset -1px 0 #ffffff14, 10px 0 34px #142a441a;
}

.side-brand {
  justify-content: space-between;
  align-items: center;
  height: 62px;
  padding: 0 18px;
  display: flex;
}

.brand {
  color: var(--surface);
  align-items: center;
  gap: 9px;
  font-size: 16px;
  font-weight: 800;
  text-decoration: none;
  display: flex;
}

.brand-mark {
  background: var(--surface-raised);
  border: 1px solid #ffffff57;
  border-radius: 999px;
  place-items: center;
  width: 34px;
  height: 34px;
  display: grid;
  overflow: hidden;
  box-shadow: 0 8px 22px #0003;
}

.brand-mark-image {
  background-image: url("https://www.skku.edu/_res/skku/img/common/favicon-ios.png");
  background-position: center;
  background-size: cover;
  width: 100%;
  height: 100%;
}

.side-nav {
  flex-direction: column;
  gap: 10px;
  padding: 8px 12px;
  display: flex;
}

.nav-section {
  gap: 6px;
  display: grid;
}

.nav-section-primary {
  gap: 8px;
}

.nav-section-title {
  color: #ffffff85;
  text-transform: uppercase;
  margin: 4px 4px 0;
  font-size: 10px;
  font-weight: 800;
}

.nav-children {
  padding-left: 12px;
}

.nav-tab {
  color: #ffffffc2;
  text-align: left;
  background: none;
  border: 1px solid #0000;
  border-radius: 10px;
  align-items: center;
  gap: 10px;
  width: 100%;
  min-height: 42px;
  padding: 0 12px;
  font-size: 13.5px;
  font-weight: 700;
  text-decoration: none;
  transition: background .16s, border-color .16s, color .16s, transform .16s;
  display: flex;
  position: relative;
}

.nav-icon {
  color: #ffffffdb;
  background: #ffffff17;
  border: 1px solid #ffffff24;
  border-radius: 9px;
  flex: 0 0 26px;
  place-items: center;
  width: 26px;
  height: 26px;
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  display: grid;
}

.nav-icon-svg {
  stroke: currentColor;
  stroke-width: 1.9px;
  stroke-linecap: round;
  stroke-linejoin: round;
  width: 15px;
  height: 15px;
}

.nav-label {
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
  overflow: hidden;
}

.nav-soon {
  color: #fff9;
  text-transform: uppercase;
  margin-left: auto;
  font-size: 10px;
}

.nav-tab:hover, .nav-tab.active {
  color: var(--surface);
  background: #ffffff21;
  border-color: #ffffff2e;
}

.nav-tab:hover {
  transform: translateX(1px);
}

.nav-tab:hover .nav-icon, .nav-tab.active .nav-icon {
  color: var(--surface);
  background: #fff3;
  border-color: #ffffff47;
}

.nav-tab.active {
  background: var(--surface-raised);
  color: var(--accent-strong);
  font-weight: 800;
  box-shadow: 0 10px 24px #00000029;
}

.nav-tab.active .nav-icon {
  color: var(--accent);
  background: #7dad4724;
  border-color: #0044831f;
}

.sidebar-fold {
  background: #00000029;
  border: 1px solid #ffffff29;
  border-radius: 10px;
  min-height: 0;
  margin: 2px 12px 8px;
}

.side-nav .sidebar-fold {
  margin: 0;
}

.nav-history-fold {
  margin-top: 0;
}

.sidebar-fold summary {
  color: #ffffffbd;
  cursor: pointer;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  min-height: 34px;
  padding: 0 10px;
  font-size: 12px;
  list-style: none;
  display: flex;
}

.sidebar-fold summary::-webkit-details-marker {
  display: none;
}

.sidebar-fold summary:before {
  content: "▾";
  color: #fff9;
  font-size: 10px;
}

.sidebar-fold:not([open]) summary:before {
  content: "▸";
}

.sidebar-fold summary span {
  flex: 1;
}

.sidebar-fold summary code {
  color: #ffffff9e;
  font-size: 10px;
}

.mini-btn, .sidebar-session-actions button {
  color: #ffffffad;
  background: #ffffff14;
  border: 1px solid #ffffff24;
  border-radius: 8px;
  min-height: 28px;
  font-size: 11px;
  font-weight: 700;
}

.sidebar-refresh {
  width: calc(100% - 16px);
  margin: 0 8px 8px;
}

.sidebar-note {
  color: #ffffff94;
  margin: 0 8px 8px;
  font-size: 11px;
}

.sidebar-note.is-error {
  color: #eea285;
  color: lab(73.808% 26.6331 27.4554);
}

.sidebar-history-list {
  scrollbar-width: thin;
  flex-direction: column;
  gap: 6px;
  max-height: min(36vh, 300px);
  padding: 0 8px 8px;
  display: flex;
  overflow: auto;
}

.sidebar-session-row {
  background: none;
  border: 1px solid #0000;
  border-radius: 9px;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 4px;
  display: grid;
}

.sidebar-session-row:hover, .sidebar-session-row.active {
  background: #ffffff1a;
  border-color: #ffffff2e;
}

.sidebar-session-main {
  text-align: left;
  min-width: 0;
  padding: 8px;
}

.sidebar-session-main strong {
  color: #ffffffdb;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  font-weight: 650;
  display: block;
  overflow: hidden;
}

.sidebar-session-main small {
  color: #ffffff85;
  flex-wrap: wrap;
  gap: 4px;
  min-width: 0;
  margin-top: 3px;
  font-size: 10px;
  display: flex;
}

.session-dot {
  background: var(--green);
  border-radius: 999px;
  align-self: center;
  width: 6px;
  height: 6px;
}

.sidebar-session-actions {
  opacity: 0;
  gap: 3px;
  padding: 6px 6px 0 0;
  transition: opacity .16s;
  display: flex;
}

.sidebar-session-row:hover .sidebar-session-actions, .sidebar-session-row:focus-within .sidebar-session-actions {
  opacity: 1;
}

.sidebar-session-actions button {
  min-width: 24px;
  padding: 0 5px;
  font-size: 10px;
}

.side-footer {
  border-top: 1px solid #ffffff29;
  margin-top: auto;
  padding: 14px;
}

.settings-button {
  color: #ffffffd6;
  background: #0000002e;
  border: 1px solid #ffffff2e;
  border-radius: 9px;
  justify-content: flex-start;
  align-items: center;
  gap: 9px;
  width: 100%;
  min-height: 38px;
  padding: 0 12px;
  font-weight: 650;
  display: flex;
}

.settings-button:hover {
  color: var(--surface);
  background: #ffffff1f;
  border-color: #ffffff57;
}

.settings-icon {
  width: 20px;
  height: 20px;
  color: var(--accent-2);
  place-items: center;
  display: grid;
}

.main-pane {
  background: linear-gradient(180deg,
      #fbfdffa8,
      #fbfdff00 210px),
    var(--bg);
  flex-direction: column;
  flex: 1;
  min-width: 0;
  display: flex;
}

.main-top {
  background: #fbfdffe0;
  border-bottom: 1px solid #0044831a;
  flex: 0 0 56px;
  justify-content: space-between;
  align-items: center;
  height: 56px;
  padding: 0 32px;
  display: flex;
  box-shadow: 0 8px 24px #142a440f;
}

.main-top h1 {
  color: var(--text);
  margin: 0;
  font-size: 15px;
  font-weight: 750;
}

.main-title-row {
  align-items: center;
  gap: 10px;
  min-width: 0;
  display: flex;
}

.main-title-row h1 {
  white-space: nowrap;
  flex: none;
}

.top-actions {
  gap: 8px;
  display: flex;
}

.chat-reference-picker {
  min-width: 0;
}

.chat-reference-trigger {
  min-height: 30px;
  color: var(--text-soft);
  white-space: nowrap;
  background: #fbfdffc7;
  border-radius: 9px;
  align-items: center;
  gap: 6px;
  display: inline-flex;
}

.chat-reference-trigger:hover, .chat-reference-trigger:focus-visible {
  border-color: var(--border-strong);
  color: var(--accent-strong);
  background: #00448312;
}

.chat-reference-count {
  color: var(--muted-2);
}

.top-recall.chat-reference-picker {
  z-index: 45;
  width: auto;
  position: relative;
}

.top-recall .chat-reference-panel {
  width: min(760px, calc(100vw - var(--sidebar-width) - 48px));
  max-height: min(68vh, 520px);
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  overflow: auto;
  box-shadow: 0 18px 48px #142a4429;
}

.ghost-btn, .solid-btn {
  border: 1px solid var(--border);
  min-height: 32px;
  color: var(--muted);
  background: #fbfdffc2;
  border-radius: 10px;
  padding: 0 13px;
  font-size: 12px;
}

.ghost-btn:hover, .solid-btn:hover {
  border-color: var(--border-strong);
  color: var(--text);
  box-shadow: 0 6px 18px #142a4414;
}

.ghost-btn:disabled, .solid-btn:disabled {
  cursor: default;
  opacity: .45;
}

.solid-btn {
  border-color: var(--accent);
  background: var(--accent);
  color: var(--surface);
}

.main-stage {
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

.main-stage > :not(.chat-view) {
  height: 100%;
  overflow: auto;
}

.books-workspace {
  background: var(--bg);
  height: 100%;
  min-height: 0;
  color: var(--text);
  flex-direction: column;
  display: flex;
  overflow: hidden;
}

.book-library-shell {
  background: var(--bg);
  flex-direction: column;
  flex: 1;
  min-height: 0;
  display: flex;
  overflow: hidden;
}

.book-library-header, .book-reader-header {
  border-bottom: 1px solid var(--border);
  background: #fbfdffe0;
  flex: none;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  min-height: 62px;
  padding: 12px 24px;
  display: flex;
}

.book-library-title, .book-reader-title {
  align-items: center;
  gap: 12px;
  min-width: 0;
  display: flex;
}

.book-library-title h2, .book-reader-title h2 {
  color: var(--text);
  margin: 0;
  font-size: 15px;
  font-weight: 800;
  line-height: 1.25;
}

.book-library-title p, .book-reader-title p {
  max-width: 68ch;
  color: var(--muted);
  text-overflow: ellipsis;
  white-space: nowrap;
  margin: 2px 0 0;
  font-size: 12px;
  line-height: 1.35;
  overflow: hidden;
}

.book-skku-mark, .book-cover-emblem {
  background-image: url("https://www.skku.edu/_res/skku/img/common/favicon-ios.png");
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  place-items: center;
  display: inline-grid;
}

.book-skku-mark {
  background-color: #e3e6df;
  background-color: lab(90.8354% -2.00832 3.07137);
  border: 1px solid #a7ada047;
  border: 1px solid lab(70.0673% -3.97992 6.18016 / .28);
  border-radius: 8px;
  flex: 0 0 32px;
  width: 32px;
  height: 32px;
  box-shadow: 0 10px 24px #142a441f;
}

.book-library-actions, .book-reader-actions {
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  gap: 8px;
  display: flex;
}

.book-search-field {
  align-items: center;
  width: min(224px, 32vw);
  height: 34px;
  display: flex;
  position: relative;
}

.book-search-field span {
  color: var(--muted-2);
  font-size: 10px;
  font-weight: 800;
  position: absolute;
  left: 10px;
}

.book-search-field input, .book-create-panel input {
  border: 1px solid var(--border);
  background: var(--surface);
  width: 100%;
  height: 100%;
  color: var(--text);
  border-radius: 7px;
  outline: none;
  font-size: 12px;
}

.book-search-field input {
  padding: 0 10px 0 28px;
}

.book-create-panel input {
  flex: 1;
  min-width: min(340px, 100%);
  padding: 0 12px;
}

.book-search-field input::-moz-placeholder {
  color: var(--muted-2);
}

.book-create-panel input::-moz-placeholder {
  color: var(--muted-2);
}

.book-search-field input::placeholder, .book-create-panel input::placeholder {
  color: var(--muted-2);
}

.book-search-field input:focus, .book-create-panel input:focus {
  border-color: var(--accent-strong);
  box-shadow: 0 0 0 3px #7697362e;
  box-shadow: 0 0 0 3px lab(58.3197% -23.2936 45.3036 / .18);
}

.book-primary-action, .book-secondary-action, .book-danger-action, .book-library-alert button {
  border: 1px solid #0000;
  border-radius: 7px;
  justify-content: center;
  align-items: center;
  gap: 7px;
  min-height: 32px;
  padding: 0 12px;
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  transition: border-color .16s, background .16s, color .16s, opacity .16s, transform .16s;
  display: inline-flex;
}

.book-primary-action {
  background: var(--accent);
  color: var(--surface);
}

.book-secondary-action, .book-library-alert button {
  border-color: var(--border);
  background: var(--surface-2);
  color: var(--text-soft);
}

.book-danger-action {
  color: var(--red);
  background: #feeeeb;
  background: lab(95.2105% 5.26717 3.49728);
  border-color: #d2564573;
  border-color: lab(53.2757% 49.0932 35.5242 / .45);
}

.book-primary-action:hover, .book-secondary-action:hover, .book-danger-action:hover, .book-library-alert button:hover {
  opacity: .92;
  transform: translateY(-1px);
}

.book-primary-action:disabled, .book-secondary-action:disabled, .book-danger-action:disabled {
  cursor: default;
  opacity: .48;
  transform: none;
}

.book-library-alert {
  border-bottom: 1px solid var(--border);
  color: var(--red);
  background: #feeeeb;
  background: lab(95.2105% 5.26717 3.49728);
  flex: none;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 9px 24px;
  font-size: 12px;
  display: flex;
}

.book-create-panel {
  border-bottom: 1px solid var(--border);
  background: var(--surface);
  flex-wrap: wrap;
  flex: none;
  align-items: center;
  gap: 10px;
  padding: 12px 24px;
  display: flex;
}

.book-library-main {
  flex: 1;
  min-height: 0;
  padding: 24px;
  overflow-y: auto;
}

.book-stat-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 26px;
  display: grid;
}

.book-stat-card {
  border: 1px solid var(--border);
  background: var(--surface);
  border-radius: 9px;
  min-height: 74px;
  padding: 13px 16px;
}

.book-stat-card div {
  color: var(--muted);
  letter-spacing: .08em;
  text-transform: uppercase;
  align-items: center;
  gap: 7px;
  font-size: 11px;
  font-weight: 800;
  display: flex;
}

.book-stat-card span {
  color: var(--muted-2);
}

.book-stat-card[data-tone="ready"] span, .book-stat-card[data-tone="ready"] strong {
  color: var(--accent-strong);
}

.book-stat-card[data-tone="progress"] span, .book-stat-card[data-tone="progress"] strong {
  color: #6461bd;
  color: lab(44.8577% 20.0619 -48.9282);
}

.book-stat-card strong {
  color: var(--text);
  margin-top: 6px;
  font-size: 21px;
  line-height: 1;
  display: block;
}

.book-library-section-title {
  justify-content: space-between;
  align-items: end;
  margin-bottom: 12px;
  display: flex;
}

.book-library-section-title p {
  color: var(--muted);
  letter-spacing: .16em;
  text-transform: uppercase;
  margin: 0;
  font-size: 11px;
  font-weight: 800;
}

.book-library-section-title span {
  color: var(--text-soft);
  margin-top: 1px;
  font-size: 12px;
  display: block;
}

.book-card-grid {
  grid-template-columns: repeat(2, minmax(260px, 380px));
  align-items: stretch;
  gap: 18px;
  display: grid;
}

.book-library-card {
  border: 1px solid var(--border);
  background: var(--surface);
  cursor: pointer;
  border-radius: 9px;
  outline: none;
  min-width: 0;
  transition: border-color .18s, box-shadow .18s, transform .18s;
  position: relative;
  overflow: hidden;
}

.book-library-card:hover, .book-library-card:focus-visible {
  box-shadow: var(--shadow-soft);
  border-color: #809f499e;
  border-color: lab(61.7321% -21.8189 40.7596 / .62);
  transform: translateY(-2px);
}

.book-cover {
  height: 112px;
  position: relative;
  overflow: hidden;
}

.book-cover-glow {
  pointer-events: none;
  position: absolute;
  inset: 0;
}

.book-cover-spine {
  width: 9px;
  position: absolute;
  inset: 0 auto 0 0;
}

.book-cover-line {
  opacity: .5;
  width: 1px;
  position: absolute;
  top: 14px;
  bottom: 14px;
  left: 15px;
}

.book-cover-emblem {
  opacity: .74;
  border-radius: 7px;
  width: 24px;
  height: 24px;
  position: absolute;
  bottom: 14px;
  right: 16px;
}

.book-card-status {
  color: #15632f;
  color: lab(36.4143% -33.3336 22.1178);
  letter-spacing: .06em;
  text-transform: uppercase;
  background: #d1ddc194;
  background: lab(86.5264% -7.87631 12.4538 / .58);
  border-radius: 999px;
  align-items: center;
  gap: 5px;
  padding: 3px 9px;
  font-size: 10px;
  font-weight: 800;
  display: inline-flex;
  position: absolute;
  top: 12px;
  left: 18px;
}

.book-card-status i {
  background: currentColor;
  border-radius: 999px;
  width: 6px;
  height: 6px;
}

.book-card-status[data-tone="progress"] {
  color: #5650b2;
  color: lab(38.7712% 23.4774 -52.2253);
  background: #d3d5f294;
  background: lab(85.7377% 3.42649 -14.5979 / .58);
}

.book-card-status[data-tone="error"] {
  color: #ac3225;
  color: lab(40.4807% 49.489 37.7892);
  background: #f1cec894;
  background: lab(85.7433% 11.7816 7.84519 / .58);
}

.book-card-status[data-tone="unknown"] {
  color: #58554f;
  color: lab(36.2221% .730842 3.77197);
  background: #e2ddd794;
  background: lab(88.4239% .698715 3.74981 / .58);
}

.book-card-delete {
  color: #433c31;
  color: lab(25.7938% 1.64951 7.69839);
  opacity: 0;
  background: #fcf8f1a3;
  background: lab(97.704% .696033 3.74807 / .64);
  border: 1px solid #f2eee773;
  border: 1px solid lab(94.224% .696987 3.74869 / .45);
  border-radius: 7px;
  width: 28px;
  height: 28px;
  font-size: 14px;
  font-weight: 800;
  transition: background .16s, color .16s, opacity .16s;
  position: absolute;
  top: 10px;
  right: 10px;
}

.book-library-card:hover .book-card-delete, .book-card-delete[data-confirm="true"], .book-card-delete:focus-visible {
  opacity: 1;
}

.book-card-delete[data-confirm="true"] {
  color: #f8efee;
  color: lab(95.2773% 2.91997 1.93757);
  background: #e05b4a;
  background: lab(56.6607% 52.1872 37.8583);
}

.book-card-body {
  flex-direction: column;
  gap: 8px;
  min-height: 142px;
  padding: 16px;
  display: flex;
}

.book-card-body h3 {
  min-height: 38px;
  color: var(--text);
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  margin: 0;
  font-size: 15px;
  font-weight: 800;
  line-height: 1.25;
  display: -webkit-box;
  overflow: hidden;
}

.book-card-body p {
  min-height: 54px;
  color: var(--muted);
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  margin: 0;
  font-size: 12px;
  line-height: 1.5;
  display: -webkit-box;
  overflow: hidden;
}

.book-card-meta {
  color: var(--muted);
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 8px 14px;
  margin-top: auto;
  font-size: 11px;
  display: flex;
}

.book-card-meta time {
  margin-left: auto;
}

.book-library-state, .book-empty-state {
  border: 1px dashed var(--border-strong);
  background: var(--surface);
  min-height: 220px;
  color: var(--muted);
  border-radius: 9px;
  justify-content: center;
  align-items: center;
  font-size: 13px;
  display: flex;
}

.book-empty-state {
  text-align: center;
  flex-direction: column;
  gap: 14px;
}

.book-empty-state p {
  margin: 0;
}

.book-reader-title {
  align-items: flex-start;
}

.book-reader-body {
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

.book-reader-body > section {
  height: 100%;
}

.book-guide-sidebar {
  border-right: 1px solid var(--border);
  background: var(--surface);
  flex-direction: column;
  flex-shrink: 0;
  width: 310px;
  display: flex;
}

.book-guide-header {
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, #0044830b, transparent),
    var(--surface);
  flex: none;
  padding: 15px 14px 12px;
}

.book-guide-title-row {
  justify-content: space-between;
  align-items: baseline;
  gap: 10px;
  display: flex;
}

.book-guide-kicker {
  color: var(--text);
  font-size: 13px;
  font-weight: 850;
}

.book-guide-count {
  color: var(--muted);
  white-space: nowrap;
  font-size: 11px;
}

.book-guide-progress {
  background: var(--surface-2);
  border-radius: 999px;
  height: 5px;
  margin-top: 11px;
  overflow: hidden;
}

.book-guide-progress span {
  border-radius: inherit;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  height: 100%;
  display: block;
}

.book-guide-scroll {
  flex: 1;
  min-height: 0;
  padding: 10px 10px 14px;
  overflow-y: auto;
}

.book-guide-tree {
  gap: 8px;
  display: grid;
}

.book-guide-weak {
  color: var(--red);
  white-space: nowrap;
  border: 1px solid #be4c2a47;
  border-radius: 999px;
  padding: 2px 6px;
  font-size: 10px;
  font-weight: 750;
}

.book-guide-entry {
  border: 1px solid var(--border);
  background: var(--surface);
  width: 100%;
  color: var(--text-soft);
  text-align: left;
  border-radius: 10px;
  grid-template-columns: 32px minmax(0, 1fr) auto;
  align-items: start;
  gap: 10px;
  padding: 11px 10px;
  transition: background .16s, border-color .16s, box-shadow .16s;
  display: grid;
  box-shadow: 0 7px 18px #142a440d;
}

.book-guide-entry:hover {
  border-color: var(--border-strong);
  background: var(--surface-2);
}

.book-guide-entry[data-active="true"] {
  background: var(--surface-3);
  color: var(--text);
  border-color: #0044832e;
  box-shadow: 0 10px 22px #142a4414;
}

.book-guide-entry-index {
  width: 32px;
  height: 32px;
  color: var(--accent);
  background: #00448314;
  border-radius: 9px;
  place-items: center;
  font-size: 11px;
  font-weight: 850;
  display: grid;
}

.book-guide-entry[data-active="true"] .book-guide-entry-index {
  background: var(--accent);
  color: var(--surface);
}

.book-guide-entry-body {
  gap: 4px;
  min-width: 0;
  display: grid;
}

.book-guide-entry-title {
  color: inherit;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12.5px;
  font-weight: 820;
  line-height: 1.35;
  overflow: hidden;
}

.book-guide-entry-summary {
  color: var(--muted);
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  font-size: 10.5px;
  line-height: 1.45;
  display: -webkit-box;
  overflow: hidden;
}

.book-guide-entry-meta, .book-guide-entry-flags {
  color: var(--muted);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 10px;
  line-height: 1.35;
  overflow: hidden;
}

.book-guide-entry-flags {
  color: var(--accent-2-strong);
}

.book-guide-empty {
  color: var(--muted);
  padding: 18px 10px;
  font-size: 12px;
}

.view {
  min-height: 0;
  display: none;
}

.view.active {
  display: block;
}

.chat-view {
  height: 100%;
  position: relative;
  overflow: hidden;
}

.welcome {
  text-align: center;
  pointer-events: none;
  width: min(720px, 100% - 80px);
  position: absolute;
  top: 30%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.welcome h2 {
  color: var(--accent);
  font-family: var(--serif);
  margin: 0 0 16px;
  font-size: 42px;
  font-weight: 700;
  line-height: 1.15;
}

.welcome p {
  color: var(--muted);
  margin: 0;
  font-size: 15px;
}

.thread {
  scrollbar-width: thin;
  height: calc(100% - 148px);
  padding: 24px min(13vw, 190px) 220px;
  overflow: auto;
}

.thread-actions {
  width: min(720px, 100%);
  margin: 0 auto 12px;
}

.message {
  width: min(720px, 100%);
  color: var(--text-soft);
  margin: 0 auto 18px;
}

.message.user {
  justify-content: flex-end;
  display: flex;
}

.message.user .message-body {
  background: var(--surface-raised);
  max-width: min(600px, 82%);
  color: var(--text);
  box-shadow: var(--shadow-tight);
  border: 1px solid #0044831f;
  border-radius: 15px;
  padding: 12px 14px;
}

.message.assistant .message-body {
  color: var(--text-soft);
  padding: 2px 0;
}

.message-body {
  overflow-wrap: anywhere;
  white-space: pre-wrap;
}

.message-chip-row {
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
  display: flex;
}

.message-chip {
  color: var(--muted);
  background: #00448314;
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 10px;
}

.message-foot {
  color: var(--muted-2);
  font-family: var(--mono);
  align-items: center;
  gap: 8px;
  margin-top: 6px;
  font-size: 10px;
  display: flex;
}

.message-error {
  color: var(--red);
}

.assistant-main-content {
  color: #252f3a;
  color: lab(18.7416% -1.84079 -8.44651);
  white-space: normal;
  gap: 10px;
  max-width: min(760px, 100%);
  font-size: 15px;
  line-height: 1.72;
  display: grid;
}

.assistant-empty {
  color: var(--muted);
  font-style: italic;
}

.assistant-trace {
  max-width: min(760px, 100%);
  color: var(--muted);
  overflow-wrap: normal;
  white-space: normal;
  gap: 6px;
  margin: 0 0 10px;
  font-size: 11px;
  line-height: 1.55;
  display: grid;
}

.assistant-trace-item {
  background: #f7fafe;
  background: lab(98.2525% -.595033 -2.17147);
  border: 1px solid #0044831a;
  border-radius: 8px;
  overflow: hidden;
}

.assistant-trace-item[open] {
  background: #f2f7fe;
  background: lab(97.0869% -.979662 -3.61223);
}

.assistant-trace-summary {
  cursor: pointer;
  align-items: center;
  gap: 7px;
  min-width: 0;
  padding: 7px 9px;
  list-style: none;
  display: flex;
}

.assistant-trace-summary::-webkit-details-marker {
  display: none;
}

.assistant-trace-chevron {
  color: #4d5c6e;
  color: lab(38.4416% -2.69015 -11.9948);
  border: 1.5px solid;
  border-width: 0 1.5px 1.5px 0;
  flex: none;
  width: 6px;
  height: 6px;
  transition: transform .16s ease-out;
  transform: rotate(-45deg);
}

.assistant-trace-item[open] .assistant-trace-chevron {
  transform: rotate(45deg);
}

.assistant-trace-kind {
  color: #283748;
  color: lab(22.1749% -2.42326 -12.5648);
  min-width: 0;
  font-weight: 700;
}

.assistant-trace-duration {
  color: var(--muted-2);
  flex: none;
}

.assistant-trace-state {
  color: #404f5f;
  color: lab(32.6368% -2.59753 -11.9624);
  flex: none;
  font-weight: 700;
}

.assistant-trace-state[data-state="complete"] {
  color: var(--green);
}

.assistant-trace-state[data-state="error"] {
  color: var(--red);
}

.assistant-trace-separator {
  color: var(--muted-2);
  flex: none;
}

.assistant-trace-live {
  background: var(--accent);
  opacity: .76;
  border-radius: 999px;
  flex: none;
  width: 6px;
  height: 6px;
  animation: 1.1s ease-out infinite trace-live;
}

.assistant-trace-count {
  color: #425163;
  color: lab(33.7902% -2.71858 -12.6554);
  text-align: center;
  background: #0044830b;
  border: 1px solid #0044831a;
  border-radius: 999px;
  flex: none;
  min-width: 18px;
  height: 18px;
  font-size: 10px;
  font-weight: 700;
  line-height: 16px;
}

.assistant-trace-detail {
  border-top: 1px solid #00448314;
  gap: 0;
  padding: 0 10px 9px;
  display: grid;
}

.assistant-trace-event {
  border-top: 1px solid #0044830f;
  gap: 5px;
  min-width: 0;
  padding: 8px 0;
  display: grid;
}

.assistant-trace-event:first-child {
  border-top: 0;
}

.assistant-trace-event-head {
  color: #34414f;
  color: lab(26.8465% -2.2907 -10.5546);
  overflow-wrap: break-word;
  white-space: normal;
  min-width: 0;
  font-weight: 700;
}

.assistant-trace-event-body {
  color: #333333ad;
  overflow-wrap: break-word;
  white-space: normal;
  font-size: 12px;
  line-height: 1.65;
}

.assistant-trace-structured {
  gap: 8px;
  min-width: 0;
  display: grid;
}

.assistant-trace-structured-field {
  background: #fafcfec7;
  background: lab(98.8351% -.399023 -1.44904 / .78);
  border: 1px solid #00448313;
  border-radius: 7px;
  gap: 4px;
  min-width: 0;
  padding: 7px 8px;
  display: grid;
}

.assistant-trace-structured-label {
  color: #404f5f;
  color: lab(32.6368% -2.59753 -11.9624);
  letter-spacing: 0;
  text-transform: uppercase;
  font-size: 10px;
  font-weight: 800;
  line-height: 1.35;
}

.assistant-trace-structured-text {
  color: #333333b8;
  overflow-wrap: break-word;
  font-size: 12px;
  line-height: 1.65;
}

.assistant-trace-structured-list {
  color: #333333b8;
  gap: 4px;
  margin: 0;
  padding-left: 16px;
  font-size: 12px;
  line-height: 1.55;
  display: grid;
}

.assistant-trace-structured-list--blocks {
  gap: 6px;
  padding-left: 0;
  list-style: none;
}

.assistant-trace-structured-list--blocks li {
  overflow-wrap: break-word;
  white-space: normal;
  background: #f6f9fcdb;
  background: lab(97.6725% -.594974 -2.17145 / .86);
  border: 1px solid #00448311;
  border-radius: 6px;
  padding: 6px 7px;
}

.assistant-trace-structured-code {
  color: #333333b8;
  background: #f1f6fa;
  background: lab(96.5097% -.788301 -2.89243);
  border-radius: 6px;
  max-height: 260px;
  margin: 0;
  padding: 8px;
  font-size: 11px;
  line-height: 1.55;
  overflow: auto;
}

.assistant-trace-meta {
  flex-wrap: wrap;
  gap: 4px;
  min-width: 0;
  display: flex;
}

.assistant-trace-meta span {
  max-width: 100%;
  color: var(--muted-2);
  overflow-wrap: normal;
  text-overflow: ellipsis;
  white-space: nowrap;
  word-break: keep-all;
  background: #fafcfebd;
  background: lab(98.8351% -.399023 -1.44904 / .74);
  border: 1px solid #00448314;
  border-radius: 999px;
  padding: 2px 6px;
  overflow: hidden;
}

.assistant-stream-cursor {
  background: var(--accent);
  vertical-align: -.16em;
  border-radius: 999px;
  width: 6px;
  height: 1.15em;
  margin-left: 1px;
  animation: .95s steps(2, start) infinite stream-cursor;
  display: inline-block;
}

.assistant-main-content p, .prose-tight p {
  margin: 0;
}

.book-quiz-question {
  writing-mode: horizontal-tb;
  word-break: normal;
  overflow-wrap: anywhere;
  min-width: 0;
}

.book-quiz-question p {
  max-width: 72ch;
}

.assistant-main-content h1, .assistant-main-content h2, .assistant-main-content h3, .assistant-main-content h4, .assistant-main-content h5, .prose-tight h1, .prose-tight h2, .prose-tight h3, .prose-tight h4, .prose-tight h5 {
  color: var(--text);
  margin: 6px 0 0;
  font-size: 17px;
  line-height: 1.35;
}

.assistant-main-content ul, .assistant-main-content ol, .prose-tight ul, .prose-tight ol {
  gap: 5px;
  margin: 0;
  padding-left: 22px;
  display: grid;
}

.assistant-main-content li, .prose-tight li {
  padding-left: 2px;
}

.assistant-main-content strong, .prose-tight strong {
  color: var(--text);
  font-weight: 700;
}

.assistant-main-content code, .prose-tight code {
  border: 1px solid var(--border);
  background: var(--surface-2);
  color: var(--accent);
  font-family: var(--mono);
  border-radius: 6px;
  padding: 2px 5px;
  font-size: .9em;
}

.assistant-main-content pre, .prose-tight pre {
  border: 1px solid var(--border);
  background: var(--surface-2);
  max-width: 100%;
  color: var(--text-soft);
  font-family: var(--mono);
  white-space: pre;
  border-radius: 8px;
  margin: 0;
  padding: 12px;
  font-size: 12px;
  line-height: 1.55;
  overflow: auto;
}

.assistant-main-content pre code, .prose-tight pre code {
  color: inherit;
  font-size: inherit;
  background: none;
  border: 0;
  padding: 0;
}

.mermaid-block {
  border: 1px solid var(--border);
  background: var(--bg);
  border-radius: 8px;
  max-width: 100%;
  margin: 6px 0;
  overflow: hidden;
}

.mermaid-block__viewport {
  width: 100%;
  padding: 14px;
  overflow: auto;
}

.mermaid-block svg {
  width: max-content;
  min-width: 420px;
  max-width: 100%;
  height: auto;
  margin: 0 auto;
  display: block;
}

.mermaid-block--loading {
  padding: 14px;
}

.mermaid-block__skeleton {
  background: linear-gradient(90deg,
      transparent,
      #00448314,
      transparent),
    var(--surface-2);
  background-size: 220px 100%, 100% 100%;
  border-radius: 6px;
  height: 180px;
  animation: 1.2s ease-out infinite mermaid-skeleton;
}

.mermaid-block--source {
  padding: 10px 12px;
}

.mermaid-block--source summary {
  cursor: pointer;
  color: var(--text-soft);
  font-size: 12px;
  font-weight: 600;
}

.mermaid-block__error {
  color: var(--red);
  margin-top: 8px;
  font-size: 12px;
  line-height: 1.5;
}

.mermaid-block--source pre {
  margin-top: 10px;
}

@keyframes mermaid-skeleton {
  from {
    background-position: -220px 0, 0 0;
  }

  to {
    background-position: calc(100% + 220px) 0, 0 0;
  }
}

.assistant-main-content a, .prose-tight a {
  color: var(--blue);
  text-underline-offset: 2px;
  text-decoration: underline;
}

.assistant-main-content blockquote, .prose-tight blockquote {
  border: 1px solid var(--border);
  color: var(--muted);
  background: #0044830b;
  border-radius: 9px;
  gap: 6px;
  margin: 0;
  padding: 10px 12px;
  display: grid;
}

.assistant-main-content table, .prose-tight table {
  border-collapse: collapse;
  width: 100%;
  font-size: 13px;
}

.assistant-main-content th, .assistant-main-content td, .prose-tight th, .prose-tight td {
  border: 1px solid var(--border);
  text-align: left;
  vertical-align: top;
  padding: 8px 9px;
}

.assistant-main-content th, .prose-tight th {
  background: var(--surface-2);
  color: var(--text);
  font-weight: 700;
}

@keyframes trace-live {
  0%, 100% {
    opacity: .45;
    transform: scale(.78);
  }

  50% {
    opacity: .95;
    transform: scale(1);
  }
}

@keyframes stream-cursor {
  0%, 45% {
    opacity: 0;
  }

  46%, 100% {
    opacity: .85;
  }
}

.composer {
  width: min(760px, 100% - 72px);
  box-shadow: var(--shadow-soft);
  background: #fbfdfff7;
  border: 1px solid #00448338;
  border-radius: 16px;
  position: absolute;
  bottom: 22px;
  left: 50%;
  overflow: visible;
  transform: translateX(-50%);
}

.composer.is-busy {
  border-color: #0044836b;
  box-shadow: 0 10px 30px #0044831f;
}

.composer-inner {
  flex-direction: column;
  display: flex;
}

.composer textarea.composer-input {
  resize: vertical;
  border: 0;
  border-bottom: 1px solid var(--border);
  width: 100%;
  min-height: 60px;
  max-height: 180px;
  color: var(--text-soft);
  background: none;
  border-radius: 0;
  outline: none;
  padding: 12px 15px;
  font-size: 15px;
  line-height: 1.45;
}

.composer textarea.composer-input::placeholder {
  color: var(--muted);
}

.capability-presets {
  border-bottom: 1px solid var(--border);
  scrollbar-width: thin;
  background: #f4f8fc8f;
  flex-wrap: nowrap;
  gap: 4px;
  padding: 6px 10px;
  display: flex;
  overflow-x: auto;
}

.capability-preset-btn {
  min-height: 32px;
  color: var(--text-soft);
  white-space: nowrap;
  background: #fbfdffdb;
  border: 1px solid #00448321;
  border-radius: 999px;
  flex-direction: row;
  flex: none;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  font-size: 12px;
  font-weight: 600;
  transition: border-color .18s, background .18s, color .18s, box-shadow .18s;
  display: inline-flex;
}

.capability-preset-btn span:first-child {
  background: var(--surface-2);
  width: 18px;
  height: 18px;
  color: var(--muted);
  font-family: var(--mono);
  text-align: center;
  border: 1px solid #0044831a;
  border-radius: 999px;
  place-items: center;
  font-size: 11px;
  display: grid;
}

.capability-preset-btn:hover, .capability-preset-btn:focus-visible {
  border-color: var(--border-strong);
  color: var(--text);
  box-shadow: 0 5px 14px #142a4414;
}

.capability-preset-btn.is-active {
  color: var(--accent-strong);
  background: #00448314;
  border-color: #00448352;
}

.capability-preset-btn.is-active span:first-child {
  color: var(--accent);
  background: #0044831a;
  border-color: #00448333;
}

.composer-toolbar {
  align-items: center;
  gap: 7px;
  min-height: 48px;
  padding: 8px 58px 8px 12px;
  display: flex;
  position: relative;
  overflow: visible;
}

.compact-toolbar {
  justify-content: space-between;
}

.learn-toolbar-controls {
  scrollbar-width: thin;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
  gap: 8px;
  width: auto;
  min-width: 0;
  max-width: calc(100% - 4px);
  padding-bottom: 2px;
  display: flex;
  overflow: auto hidden;
}

.learn-course-select, .learn-toolbar-controls > label, .composer-memory {
  min-width: 0;
  color: var(--muted);
  white-space: nowrap;
  grid-template-columns: auto minmax(140px, 220px);
  align-items: center;
  gap: 8px;
  font-size: 12px;
  display: grid;
}

.learn-course-select, .learn-toolbar-controls > label:not(.learn-course-select):not(.learn-capability-select) {
  flex: 0 0 270px;
}

.learn-course-select select, .learn-toolbar-controls select {
  background: var(--surface);
  width: 100%;
  min-width: 0;
  height: 32px;
  color: var(--text-soft);
  border: 1px solid #0044831a;
  border-radius: 9px;
  font-size: 12px;
}

.composer-memory {
  flex: none;
  grid-template-columns: auto repeat(2, auto);
}

.tool-toggle {
  color: var(--muted);
  white-space: nowrap;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  display: inline-flex;
}

.tool-toggle input {
  width: 13px;
  height: 13px;
  accent-color: var(--accent-2);
}

.composer-preview-btn {
  min-width: 54px;
  height: 32px;
  color: var(--muted);
  white-space: nowrap;
  background: #fbfdffbd;
  border: 1px solid #0044831f;
  border-radius: 9px;
  flex: none;
  padding: 0 10px;
  font-size: 12px;
  font-weight: 700;
}

.composer-preview-btn:hover, .composer-preview-btn:focus-visible {
  border-color: var(--border-strong);
  color: var(--accent-strong);
  background: #00448312;
}

.composer-more {
  flex: none;
  position: relative;
}

.composer-more-btn {
  height: 32px;
  color: var(--muted);
  white-space: nowrap;
  background: #fbfdffbd;
  border: 1px solid #0044831f;
  border-radius: 9px;
  align-items: center;
  gap: 6px;
  padding: 0 12px;
  font-size: 12px;
  font-weight: 700;
  display: inline-flex;
}

.composer-more-btn:hover, .composer-more-btn:focus-visible, .composer-more-btn[aria-expanded="true"] {
  border-color: var(--border-strong);
  color: var(--accent-strong);
  background: #00448312;
}

.composer-more-badge {
  background: var(--accent);
  min-width: 16px;
  height: 16px;
  color: var(--surface);
  border-radius: 999px;
  place-items: center;
  padding: 0 4px;
  font-size: 10px;
  font-weight: 700;
  display: inline-grid;
}

.composer-more-popover {
  z-index: 20;
  border: 1px solid var(--border-strong);
  background: var(--surface);
  border-radius: 12px;
  flex-direction: column;
  gap: 4px;
  min-width: 220px;
  padding: 8px;
  display: flex;
  position: absolute;
  bottom: calc(100% + 6px);
  right: 0;
  box-shadow: 0 12px 32px #0044832e;
}

.composer-more-section {
  flex-direction: column;
  gap: 4px;
  padding: 4px 6px;
  display: flex;
}

.composer-more-section-title {
  color: var(--muted);
  letter-spacing: .04em;
  text-transform: uppercase;
  font-size: 10px;
  font-weight: 700;
}

.composer-more-toggle {
  height: 28px;
  padding: 0 4px;
}

.composer-more-divider {
  background: var(--border);
  height: 1px;
  margin: 2px 0;
}

.composer-more-action {
  height: 32px;
  color: var(--text-soft);
  text-align: left;
  background: none;
  border: 0;
  border-radius: 8px;
  justify-content: flex-start;
  align-items: center;
  padding: 0 10px;
  font-size: 12px;
  display: flex;
}

.composer-more-action:hover:not(:disabled), .composer-more-action:focus-visible {
  color: var(--accent-strong);
  background: #00448312;
}

.composer-more-action:disabled {
  cursor: wait;
  opacity: .6;
}

.composer-config, .attachment-strip, .composer-error {
  border-top: 1px solid var(--border);
  padding: 7px 12px;
}

.attachment-chip {
  min-height: 28px;
  color: var(--text-soft);
  background: #fbfdffd1;
  border: 1px solid #0044831f;
  border-radius: 9px;
  font-size: 11px;
}

.attachment-chip:hover {
  border-color: var(--border-strong);
  background: #00448312;
}

.composer-config {
  background: #eff6f9b3;
  padding: 0;
}

.capability-presets + .composer-config {
  border-top: 0;
  border-bottom: 1px solid var(--border);
}

.composer-config:empty {
  display: none;
}

.capability-config {
  align-items: center;
  gap: 8px;
  min-height: 39px;
  padding: 6px 12px;
  display: flex;
  overflow-x: auto;
}

.capability-config-title, .capability-config-group > span, .config-inline-field > span {
  color: var(--muted);
  white-space: nowrap;
  flex: none;
  font-size: 11px;
  font-weight: 700;
}

.capability-config-title {
  color: var(--accent-strong);
}

.capability-config-group, .config-inline-field {
  flex: none;
  align-items: center;
  gap: 5px;
  display: inline-flex;
}

.config-chip {
  min-width: 42px;
  height: 27px;
  color: var(--text-soft);
  white-space: nowrap;
  background: #fbfdffd1;
  border: 1px solid #225e4c1f;
  border-radius: 8px;
  flex: none;
  justify-content: center;
  align-items: center;
  padding: 0 8px;
  font-size: 11px;
  font-weight: 700;
  transition: border-color .18s, background .18s, color .18s, box-shadow .18s;
  display: inline-flex;
}

.config-chip:hover, .config-chip:focus-visible {
  color: var(--text);
  border-color: #225e4c4d;
  box-shadow: 0 4px 12px #225e4c14;
}

.config-chip.is-active {
  color: var(--accent-2-strong);
  background: #327d5f1c;
  border-color: #225e4c5c;
}

.config-inline-field input {
  background: var(--surface);
  width: 132px;
  height: 27px;
  color: var(--text-soft);
  border: 1px solid #225e4c1f;
  border-radius: 8px;
  outline: none;
  padding: 0 8px;
  font-size: 11px;
}

.config-inline-field input:focus {
  border-color: #225e4c5c;
}

.config-issue {
  color: var(--red);
  white-space: nowrap;
  flex: none;
  font-size: 11px;
  font-weight: 700;
}

.attachment-strip {
  flex-wrap: wrap;
  gap: 6px;
  display: flex;
}

.attachment-chip {
  padding: 4px 8px;
}

.composer-error {
  color: var(--red);
  font-size: 10px;
}

.send-btn {
  background: var(--accent);
  width: 38px;
  height: 38px;
  color: var(--surface);
  border: 0;
  border-radius: 50%;
  margin-left: auto;
  font-size: 18px;
  position: absolute;
  bottom: 9px;
  right: 12px;
  box-shadow: 0 10px 24px #0044833d;
}

.send-btn:disabled {
  cursor: wait;
  opacity: .82;
}

.send-btn.is-loading {
  place-items: center;
  display: grid;
}

.send-btn.is-loading:before {
  content: "";
  border: 2px solid #ffffff6b;
  border-top-color: var(--surface);
  border-radius: 999px;
  width: 15px;
  height: 15px;
  animation: .8s linear infinite socartes-spin;
}

@keyframes socartes-spin {
  to {
    transform: rotate(360deg);
  }
}

.page-pet {
  --pet-left: calc(100vw - 210px);
  --pet-top: calc(100vh - 270px);
  --pet-scale: .62;
  --pet-row: 0;
  --pet-frames: 6;
  --pet-duration: 1.1s;
  z-index: 35;
  width: calc(192px * var(--pet-scale));
  height: calc(244px * var(--pet-scale));
  transform: translate3d(var(--pet-left), var(--pet-top), 0);
  pointer-events: none;
  touch-action: none;
  -webkit-user-select: none;
  user-select: none;
  position: fixed;
  top: 0;
  left: 0;
}

.pet-body {
  width: calc(192px * var(--pet-scale));
  height: calc(208px * var(--pet-scale));
  cursor: grab;
  pointer-events: auto;
  filter: drop-shadow(0 15px 16px #002a5b38);
  background: none;
  border: 0;
  padding: 0;
  position: absolute;
  bottom: 0;
  left: 0;
  overflow: hidden;
}

.pet-body:active {
  cursor: grabbing;
}

.pet-sprite {
  --sprite-y: calc(var(--pet-row) * -208px);
  --sprite-end-x: calc(var(--pet-frames) * -192px);
  width: 192px;
  height: 208px;
  image-rendering: pixelated;
  transform: scale(var(--pet-scale));
  transform-origin: 0 0;
  animation: pet-state var(--pet-duration) steps(var(--pet-frames)) infinite;
  background-image: url("/socartes-assets/pets/academicasi/sprite-3b5755e97bea.webp");
  background-repeat: no-repeat;
  background-size: 1536px 1872px;
  display: block;
}

.pet-bubble {
  width: min(260px, 100vw - 32px);
  min-height: 36px;
  color: var(--text-soft);
  text-align: left;
  opacity: 0;
  pointer-events: none;
  background: #fbfdfff0;
  border: 1px solid #0044832e;
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.35;
  transition: opacity .18s, transform .18s;
  position: absolute;
  bottom: calc(100% - 14px);
  right: 0;
  transform: translateY(6px);
  box-shadow: 0 12px 34px #002a5b24;
}

.pet-bubble.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.pet-bubble:after {
  content: "";
  background: #fbfdfff0;
  border-bottom: 1px solid #0044832e;
  border-right: 1px solid #0044832e;
  width: 12px;
  height: 12px;
  position: absolute;
  bottom: -7px;
  right: 42px;
  transform: rotate(45deg);
}

@keyframes pet-state {
  from {
    background-position: 0 var(--sprite-y);
  }

  to {
    background-position: var(--sprite-end-x) var(--sprite-y);
  }
}

@media (prefers-reduced-motion: reduce) {
  .pet-sprite, .send-btn.is-loading:before {
    animation: none;
  }
}

@media (max-width: 900px) {
  :root {
    --sidebar-width: 188px;
  }

  .main-top {
    padding: 0 18px;
  }

  .top-recall .chat-reference-panel {
    width: min(760px, 100vw - 36px);
  }

  .thread {
    padding-inline: 32px;
  }

  .composer {
    width: min(760px, 100% - 36px);
  }
}

@media (max-width: 760px) {
  .app-frame {
    display: block;
  }

  .sidebar {
    z-index: 30;
    flex-direction: row;
    align-items: center;
    width: 100%;
    height: 58px;
    position: fixed;
    inset: auto 0 0;
  }

  .side-brand, .sidebar-fold, .side-footer {
    display: none;
  }

  .side-nav {
    flex-direction: row;
    gap: 4px;
    width: 100%;
    padding: 7px 8px;
    overflow-x: auto;
  }

  .nav-section {
    display: contents;
  }

  .nav-section-title, .nav-children {
    display: none;
  }

  .nav-tab {
    flex: none;
    justify-content: center;
    width: auto;
    min-width: 72px;
    min-height: 42px;
    padding: 0 10px;
  }

  .nav-icon {
    display: none;
  }

  .main-pane {
    height: calc(100vh - 58px);
  }

  .top-recall .chat-reference-panel {
    width: calc(100vw - 36px);
    position: fixed;
    top: 56px;
    left: 18px;
  }

  .welcome {
    width: calc(100% - 36px);
  }

  .welcome h2 {
    font-size: 34px;
  }

  .thread {
    padding: 18px 18px 220px;
  }

  .message.user .message-body {
    max-width: 94%;
  }

  .composer {
    width: calc(100% - 22px);
    bottom: 74px;
  }

  .learn-course-select, .learn-toolbar-controls > label:not(.learn-course-select):not(.learn-capability-select) {
    flex-basis: 220px;
  }

  .page-pet {
    display: none;
  }
}

.placeholder\:text-\[var\(--muted-2\)\]::placeholder {
  color: var(--muted-2);
}

.hover\:border-\[var\(--accent\)\]:hover {
  border-color: var(--accent);
}

.hover\:bg-\[var\(--surface\)\]:hover {
  background-color: var(--surface);
}

.hover\:bg-\[var\(--surface-2\)\]:hover {
  background-color: var(--surface-2);
}

.hover\:bg-\[var\(--surface-3\)\]:hover {
  background-color: var(--surface-3);
}

.hover\:text-\[var\(--red\)\]:hover {
  color: var(--red);
}

.hover\:text-\[var\(--text\)\]:hover {
  color: var(--text);
}

.hover\:underline:hover {
  text-decoration-line: underline;
}

.focus\:border-\[var\(--accent\)\]:focus {
  border-color: var(--accent);
}

.disabled\:cursor-not-allowed:disabled {
  cursor: not-allowed;
}

.disabled\:text-\[var\(--muted-2\)\]:disabled {
  color: var(--muted-2);
}

.disabled\:opacity-40:disabled {
  opacity: .4;
}

.disabled\:opacity-50:disabled {
  opacity: .5;
}

.disabled\:opacity-60:disabled {
  opacity: .6;
}

.disabled\:opacity-70:disabled {
  opacity: .7;
}

.group:hover .group-hover\:opacity-100 {
  opacity: 1;
}

.dark\:border-amber-300\/60:is(.dark *) {
  border-color: #fcd34d99;
}

.dark\:border-cyan-300\/60:is(.dark *) {
  border-color: #67e8f999;
}

.dark\:border-emerald-300\/60:is(.dark *) {
  border-color: #6ee7b799;
}

.dark\:border-indigo-300\/60:is(.dark *) {
  border-color: #a5b4fc99;
}

.dark\:border-rose-300\/60:is(.dark *) {
  border-color: #fda4af99;
}

.dark\:border-sky-300\/60:is(.dark *) {
  border-color: #7dd3fc99;
}

.dark\:bg-amber-500\/\[0\.08\]:is(.dark *) {
  background-color: #f59e0b14;
}

.dark\:bg-cyan-500\/\[0\.08\]:is(.dark *) {
  background-color: #06b6d414;
}

.dark\:bg-emerald-500\/\[0\.08\]:is(.dark *) {
  background-color: #10b98114;
}

.dark\:bg-indigo-500\/\[0\.08\]:is(.dark *) {
  background-color: #6366f114;
}

.dark\:bg-rose-500\/\[0\.08\]:is(.dark *) {
  background-color: #f43f5e14;
}

.dark\:bg-sky-500\/\[0\.08\]:is(.dark *) {
  background-color: #0ea5e914;
}

.dark\:text-amber-100:is(.dark *) {
  --tw-text-opacity: 1;
  color: rgb(254 243 199 / var(--tw-text-opacity, 1));
}

.dark\:text-amber-300:is(.dark *) {
  --tw-text-opacity: 1;
  color: rgb(252 211 77 / var(--tw-text-opacity, 1));
}

.dark\:text-cyan-100:is(.dark *) {
  --tw-text-opacity: 1;
  color: rgb(207 250 254 / var(--tw-text-opacity, 1));
}

.dark\:text-cyan-300:is(.dark *) {
  --tw-text-opacity: 1;
  color: rgb(103 232 249 / var(--tw-text-opacity, 1));
}

.dark\:text-emerald-100:is(.dark *) {
  --tw-text-opacity: 1;
  color: rgb(209 250 229 / var(--tw-text-opacity, 1));
}

.dark\:text-emerald-300:is(.dark *) {
  --tw-text-opacity: 1;
  color: rgb(110 231 183 / var(--tw-text-opacity, 1));
}

.dark\:text-indigo-100:is(.dark *) {
  --tw-text-opacity: 1;
  color: rgb(224 231 255 / var(--tw-text-opacity, 1));
}

.dark\:text-indigo-300:is(.dark *) {
  --tw-text-opacity: 1;
  color: rgb(165 180 252 / var(--tw-text-opacity, 1));
}

.dark\:text-rose-100:is(.dark *) {
  --tw-text-opacity: 1;
  color: rgb(255 228 230 / var(--tw-text-opacity, 1));
}

.dark\:text-rose-300:is(.dark *) {
  --tw-text-opacity: 1;
  color: rgb(253 164 175 / var(--tw-text-opacity, 1));
}

.dark\:text-sky-100:is(.dark *) {
  --tw-text-opacity: 1;
  color: rgb(224 242 254 / var(--tw-text-opacity, 1));
}

.dark\:text-sky-300:is(.dark *) {
  --tw-text-opacity: 1;
  color: rgb(125 211 252 / var(--tw-text-opacity, 1));
}

@media (min-width: 640px) {
  .sm\:col-span-2 {
    grid-column: span 2 / span 2;
  }

  .sm\:grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .sm\:grid-cols-\[120px_1fr\] {
    grid-template-columns: 120px 1fr;
  }
}

@media (min-width: 768px) {
  .md\:grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .md\:grid-cols-\[180px_1fr\] {
    grid-template-columns: 180px 1fr;
  }
}

@media (min-width: 1024px) {
  .lg\:sticky {
    position: sticky;
  }

  .lg\:top-5 {
    top: 1.25rem;
  }

  .lg\:grid-cols-\[minmax\(0\,48rem\)_14rem\] {
    grid-template-columns: minmax(0, 48rem) 14rem;
  }

  .lg\:self-start {
    align-self: flex-start;
  }
}

@media (min-width: 1280px) {
  .xl\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .xl\:grid-cols-5 {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
}

/*# sourceMappingURL=%5Broot-of-the-server%5D__0jb3hod._.css.map*/