/*! tailwindcss v4.2.4 | MIT License | https://tailwindcss.com */
@layer properties;
@layer theme, base, components, utilities;
@layer theme {
  :root, :host {
    --font-sans: "Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;
    --font-serif: "Caveat", "Kalam", cursive;
    --font-mono: "JetBrains Mono", monospace;
    --color-red-400: oklch(70.4% 0.191 22.216);
    --color-white: #fff;
    --spacing: 0.25rem;
    --container-md: 28rem;
    --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);
    --text-3xl: 1.875rem;
    --text-3xl--line-height: calc(2.25 / 1.875);
    --text-4xl: 2.25rem;
    --text-4xl--line-height: calc(2.5 / 2.25);
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --font-weight-extrabold: 800;
    --tracking-tighter: -0.05em;
    --tracking-tight: -0.025em;
    --tracking-normal: 0em;
    --tracking-wider: 0.05em;
    --tracking-widest: 0.1em;
    --leading-tight: 1.25;
    --leading-snug: 1.375;
    --leading-relaxed: 1.625;
    --radius-md: 0.375rem;
    --radius-lg: 0.5rem;
    --radius-xl: 0.75rem;
    --animate-pulse: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
    --animate-bounce: bounce 1s infinite;
    --blur-md: 12px;
    --default-transition-duration: 150ms;
    --default-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    --default-font-family: var(--font-sans);
    --default-mono-font-family: var(--font-mono);
    --color-board: #1F2A24;
    --color-board-deep: #141C18;
    --color-chalk: #F4EFE3;
    --color-chalk-yellow: #E8C24A;
    --color-teacher-red: #C73E2C;
    --color-paper: #F1E9D2;
    --color-paper-warm: #E8DEC0;
    --color-ink: #1A1A1A;
    --color-ink-soft: #4A4744;
    --color-ink-mute: #7A7770;
    --color-line: #D9CDA8;
    --font-display: "Bebas Neue", "Oswald", sans-serif;
  }
}
@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-none {
    pointer-events: none;
  }
  .collapse {
    visibility: collapse;
  }
  .invisible {
    visibility: hidden;
  }
  .visible {
    visibility: visible;
  }
  .absolute {
    position: absolute;
  }
  .fixed {
    position: fixed;
  }
  .relative {
    position: relative;
  }
  .static {
    position: static;
  }
  .sticky {
    position: sticky;
  }
  .inset-0 {
    inset: calc(var(--spacing) * 0);
  }
  .start {
    inset-inline-start: var(--spacing);
  }
  .end {
    inset-inline-end: var(--spacing);
  }
  .top-0 {
    top: calc(var(--spacing) * 0);
  }
  .top-1\/2 {
    top: calc(1 / 2 * 100%);
  }
  .top-\[-12px\] {
    top: -12px;
  }
  .top-\[-14px\] {
    top: -14px;
  }
  .top-\[18px\] {
    top: 18px;
  }
  .right-2\.5 {
    right: calc(var(--spacing) * 2.5);
  }
  .right-7 {
    right: calc(var(--spacing) * 7);
  }
  .right-\[10\%\] {
    right: 10%;
  }
  .bottom-1\.5 {
    bottom: calc(var(--spacing) * 1.5);
  }
  .left-6 {
    left: calc(var(--spacing) * 6);
  }
  .left-\[12\%\] {
    left: 12%;
  }
  .z-30 {
    z-index: 30;
  }
  .col-span-1 {
    grid-column: span 1 / span 1;
  }
  .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;
    }
  }
  .m-0 {
    margin: calc(var(--spacing) * 0);
  }
  .mx-auto {
    margin-inline: auto;
  }
  .my-auto {
    margin-block: auto;
  }
  .mt-0\.5 {
    margin-top: calc(var(--spacing) * 0.5);
  }
  .mt-1 {
    margin-top: calc(var(--spacing) * 1);
  }
  .mt-1\.5 {
    margin-top: calc(var(--spacing) * 1.5);
  }
  .mt-2 {
    margin-top: calc(var(--spacing) * 2);
  }
  .mt-2\.5 {
    margin-top: calc(var(--spacing) * 2.5);
  }
  .mt-3 {
    margin-top: calc(var(--spacing) * 3);
  }
  .mt-3\.5 {
    margin-top: calc(var(--spacing) * 3.5);
  }
  .mt-4 {
    margin-top: calc(var(--spacing) * 4);
  }
  .mt-5 {
    margin-top: calc(var(--spacing) * 5);
  }
  .mt-6 {
    margin-top: calc(var(--spacing) * 6);
  }
  .mt-7 {
    margin-top: calc(var(--spacing) * 7);
  }
  .mt-8 {
    margin-top: calc(var(--spacing) * 8);
  }
  .mt-10 {
    margin-top: calc(var(--spacing) * 10);
  }
  .mt-12 {
    margin-top: calc(var(--spacing) * 12);
  }
  .mt-14 {
    margin-top: calc(var(--spacing) * 14);
  }
  .mt-32 {
    margin-top: calc(var(--spacing) * 32);
  }
  .mt-\[10px\] {
    margin-top: 10px;
  }
  .mb-0 {
    margin-bottom: calc(var(--spacing) * 0);
  }
  .mb-1 {
    margin-bottom: calc(var(--spacing) * 1);
  }
  .mb-1\.5 {
    margin-bottom: calc(var(--spacing) * 1.5);
  }
  .mb-3 {
    margin-bottom: calc(var(--spacing) * 3);
  }
  .mb-4 {
    margin-bottom: calc(var(--spacing) * 4);
  }
  .mb-5 {
    margin-bottom: calc(var(--spacing) * 5);
  }
  .mb-6 {
    margin-bottom: calc(var(--spacing) * 6);
  }
  .mb-8 {
    margin-bottom: calc(var(--spacing) * 8);
  }
  .mb-10 {
    margin-bottom: calc(var(--spacing) * 10);
  }
  .mb-12 {
    margin-bottom: calc(var(--spacing) * 12);
  }
  .mb-14 {
    margin-bottom: calc(var(--spacing) * 14);
  }
  .mb-16 {
    margin-bottom: calc(var(--spacing) * 16);
  }
  .mb-\[18px\] {
    margin-bottom: 18px;
  }
  .ml-0\.5 {
    margin-left: calc(var(--spacing) * 0.5);
  }
  .ml-1 {
    margin-left: calc(var(--spacing) * 1);
  }
  .ml-2\.5 {
    margin-left: calc(var(--spacing) * 2.5);
  }
  .ml-6 {
    margin-left: calc(var(--spacing) * 6);
  }
  .ml-auto {
    margin-left: auto;
  }
  .block {
    display: block;
  }
  .contents {
    display: contents;
  }
  .flex {
    display: flex;
  }
  .grid {
    display: grid;
  }
  .hidden {
    display: none;
  }
  .inline {
    display: inline;
  }
  .inline-block {
    display: inline-block;
  }
  .inline-flex {
    display: inline-flex;
  }
  .table {
    display: table;
  }
  .aspect-\[2\/1\] {
    aspect-ratio: 2/1;
  }
  .aspect-square {
    aspect-ratio: 1 / 1;
  }
  .h-1\.75 {
    height: calc(var(--spacing) * 1.75);
  }
  .h-2 {
    height: calc(var(--spacing) * 2);
  }
  .h-4 {
    height: calc(var(--spacing) * 4);
  }
  .h-5 {
    height: calc(var(--spacing) * 5);
  }
  .h-6 {
    height: calc(var(--spacing) * 6);
  }
  .h-11 {
    height: calc(var(--spacing) * 11);
  }
  .h-14 {
    height: calc(var(--spacing) * 14);
  }
  .h-32 {
    height: calc(var(--spacing) * 32);
  }
  .h-\[1px\] {
    height: 1px;
  }
  .h-\[24px\] {
    height: 24px;
  }
  .h-\[26px\] {
    height: 26px;
  }
  .h-\[72px\] {
    height: 72px;
  }
  .h-\[110px\] {
    height: 110px;
  }
  .h-auto {
    height: auto;
  }
  .h-full {
    height: 100%;
  }
  .max-h-\[480px\] {
    max-height: 480px;
  }
  .min-h-full {
    min-height: 100%;
  }
  .min-h-screen {
    min-height: 100vh;
  }
  .w-1\.75 {
    width: calc(var(--spacing) * 1.75);
  }
  .w-2 {
    width: calc(var(--spacing) * 2);
  }
  .w-4 {
    width: calc(var(--spacing) * 4);
  }
  .w-5 {
    width: calc(var(--spacing) * 5);
  }
  .w-6 {
    width: calc(var(--spacing) * 6);
  }
  .w-11 {
    width: calc(var(--spacing) * 11);
  }
  .w-14 {
    width: calc(var(--spacing) * 14);
  }
  .w-32 {
    width: calc(var(--spacing) * 32);
  }
  .w-\[72px\] {
    width: 72px;
  }
  .w-\[86px\] {
    width: 86px;
  }
  .w-\[220px\] {
    width: 220px;
  }
  .w-full {
    width: 100%;
  }
  .max-w-\[92\%\] {
    max-width: 92%;
  }
  .max-w-\[240px\] {
    max-width: 240px;
  }
  .max-w-\[360px\] {
    max-width: 360px;
  }
  .max-w-\[380px\] {
    max-width: 380px;
  }
  .max-w-\[480px\] {
    max-width: 480px;
  }
  .max-w-\[560px\] {
    max-width: 560px;
  }
  .max-w-\[580px\] {
    max-width: 580px;
  }
  .max-w-\[600px\] {
    max-width: 600px;
  }
  .max-w-\[620px\] {
    max-width: 620px;
  }
  .max-w-\[640px\] {
    max-width: 640px;
  }
  .max-w-\[680px\] {
    max-width: 680px;
  }
  .max-w-\[720px\] {
    max-width: 720px;
  }
  .max-w-\[820px\] {
    max-width: 820px;
  }
  .max-w-\[900px\] {
    max-width: 900px;
  }
  .max-w-\[980px\] {
    max-width: 980px;
  }
  .max-w-\[1000px\] {
    max-width: 1000px;
  }
  .max-w-\[1100px\] {
    max-width: 1100px;
  }
  .max-w-\[1240px\] {
    max-width: 1240px;
  }
  .max-w-md {
    max-width: var(--container-md);
  }
  .min-w-0 {
    min-width: calc(var(--spacing) * 0);
  }
  .min-w-\[150px\] {
    min-width: 150px;
  }
  .flex-1 {
    flex: 1;
  }
  .flex-shrink-0 {
    flex-shrink: 0;
  }
  .shrink-0 {
    flex-shrink: 0;
  }
  .flex-grow {
    flex-grow: 1;
  }
  .-translate-y-1\/2 {
    --tw-translate-y: calc(calc(1 / 2 * 100%) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .scale-105 {
    --tw-scale-x: 105%;
    --tw-scale-y: 105%;
    --tw-scale-z: 105%;
    scale: var(--tw-scale-x) var(--tw-scale-y);
  }
  .-rotate-2 {
    rotate: calc(2deg * -1);
  }
  .-rotate-3 {
    rotate: calc(3deg * -1);
  }
  .-rotate-\[0\.5deg\] {
    rotate: calc(0.5deg * -1);
  }
  .-rotate-\[1\.2deg\] {
    rotate: calc(1.2deg * -1);
  }
  .-rotate-\[1\.5deg\] {
    rotate: calc(1.5deg * -1);
  }
  .rotate-2 {
    rotate: 2deg;
  }
  .rotate-\[-0\.5deg\] {
    rotate: -0.5deg;
  }
  .rotate-\[-0\.8deg\] {
    rotate: -0.8deg;
  }
  .rotate-\[-6deg\] {
    rotate: -6deg;
  }
  .rotate-\[0\.5deg\] {
    rotate: 0.5deg;
  }
  .rotate-\[8deg\] {
    rotate: 8deg;
  }
  .transform {
    transform: var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,);
  }
  .animate-bounce {
    animation: var(--animate-bounce);
  }
  .animate-pulse {
    animation: var(--animate-pulse);
  }
  .cursor-not-allowed {
    cursor: not-allowed;
  }
  .cursor-pointer {
    cursor: pointer;
  }
  .scroll-mt-24 {
    scroll-margin-top: calc(var(--spacing) * 24);
  }
  .list-disc {
    list-style-type: disc;
  }
  .appearance-none {
    appearance: none;
  }
  .grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
  .grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .flex-col {
    flex-direction: column;
  }
  .flex-row {
    flex-direction: row;
  }
  .flex-wrap {
    flex-wrap: wrap;
  }
  .items-baseline {
    align-items: baseline;
  }
  .items-center {
    align-items: center;
  }
  .items-end {
    align-items: flex-end;
  }
  .items-start {
    align-items: flex-start;
  }
  .items-stretch {
    align-items: stretch;
  }
  .justify-between {
    justify-content: space-between;
  }
  .justify-center {
    justify-content: center;
  }
  .justify-end {
    justify-content: flex-end;
  }
  .gap-0 {
    gap: calc(var(--spacing) * 0);
  }
  .gap-1 {
    gap: calc(var(--spacing) * 1);
  }
  .gap-2 {
    gap: calc(var(--spacing) * 2);
  }
  .gap-2\.5 {
    gap: calc(var(--spacing) * 2.5);
  }
  .gap-3 {
    gap: calc(var(--spacing) * 3);
  }
  .gap-3\.5 {
    gap: calc(var(--spacing) * 3.5);
  }
  .gap-4 {
    gap: calc(var(--spacing) * 4);
  }
  .gap-5 {
    gap: calc(var(--spacing) * 5);
  }
  .gap-6 {
    gap: calc(var(--spacing) * 6);
  }
  .gap-7 {
    gap: calc(var(--spacing) * 7);
  }
  .gap-8 {
    gap: calc(var(--spacing) * 8);
  }
  .gap-12 {
    gap: calc(var(--spacing) * 12);
  }
  .gap-14 {
    gap: calc(var(--spacing) * 14);
  }
  .gap-16 {
    gap: calc(var(--spacing) * 16);
  }
  .gap-\[18px\] {
    gap: 18px;
  }
  .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-2\.5 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 2.5) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 2.5) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-4 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-6 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-10 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 10) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 10) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-\[14px\] {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(14px * var(--tw-space-y-reverse));
      margin-block-end: calc(14px * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-x-6 {
    :where(& > :not(:last-child)) {
      --tw-space-x-reverse: 0;
      margin-inline-start: calc(calc(var(--spacing) * 6) * var(--tw-space-x-reverse));
      margin-inline-end: calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-x-reverse)));
    }
  }
  .self-start {
    align-self: flex-start;
  }
  .self-stretch {
    align-self: stretch;
  }
  .justify-self-end {
    justify-self: flex-end;
  }
  .overflow-auto {
    overflow: auto;
  }
  .overflow-hidden {
    overflow: hidden;
  }
  .overflow-x-auto {
    overflow-x: auto;
  }
  .rounded {
    border-radius: 0.25rem;
  }
  .rounded-\[6px\] {
    border-radius: 6px;
  }
  .rounded-\[10px\] {
    border-radius: 10px;
  }
  .rounded-\[12px_12px_12px_2px\] {
    border-radius: 12px 12px 12px 2px;
  }
  .rounded-\[14px\] {
    border-radius: 14px;
  }
  .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);
  }
  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }
  .border-2 {
    border-style: var(--tw-border-style);
    border-width: 2px;
  }
  .border-\[1\.5px\] {
    border-style: var(--tw-border-style);
    border-width: 1.5px;
  }
  .border-t-2 {
    border-top-style: var(--tw-border-style);
    border-top-width: 2px;
  }
  .border-r {
    border-right-style: var(--tw-border-style);
    border-right-width: 1px;
  }
  .border-b {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 1px;
  }
  .border-b-2 {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 2px;
  }
  .border-l-2 {
    border-left-style: var(--tw-border-style);
    border-left-width: 2px;
  }
  .border-dashed {
    --tw-border-style: dashed;
    border-style: dashed;
  }
  .border-\[\#b8e2c5\] {
    border-color: #b8e2c5;
  }
  .border-\[rgba\(26\,26\,26\,0\.18\)\] {
    border-color: rgba(26,26,26,0.18);
  }
  .border-\[var\(--color-line\)\] {
    border-color: var(--color-line);
  }
  .border-chalk-yellow\/40 {
    border-color: color-mix(in srgb, #E8C24A 40%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      border-color: color-mix(in oklab, var(--color-chalk-yellow) 40%, transparent);
    }
  }
  .border-chalk\/40 {
    border-color: color-mix(in srgb, #F4EFE3 40%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      border-color: color-mix(in oklab, var(--color-chalk) 40%, transparent);
    }
  }
  .border-ink {
    border-color: var(--color-ink);
  }
  .border-ink\/10 {
    border-color: color-mix(in srgb, #1A1A1A 10%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      border-color: color-mix(in oklab, var(--color-ink) 10%, transparent);
    }
  }
  .border-line {
    border-color: var(--color-line);
  }
  .border-line\/70 {
    border-color: color-mix(in srgb, #D9CDA8 70%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      border-color: color-mix(in oklab, var(--color-line) 70%, transparent);
    }
  }
  .border-white {
    border-color: var(--color-white);
  }
  .border-white\/10 {
    border-color: color-mix(in srgb, #fff 10%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      border-color: color-mix(in oklab, var(--color-white) 10%, transparent);
    }
  }
  .bg-\[\#E7FFD9\] {
    background-color: #E7FFD9;
  }
  .bg-\[\#FBF5E2\] {
    background-color: #FBF5E2;
  }
  .bg-\[\#e2f1e6\] {
    background-color: #e2f1e6;
  }
  .bg-\[rgba\(232\,194\,74\,0\.55\)\] {
    background-color: rgba(232,194,74,0.55);
  }
  .bg-board {
    background-color: var(--color-board);
  }
  .bg-chalk-yellow {
    background-color: var(--color-chalk-yellow);
  }
  .bg-chalk-yellow\/10 {
    background-color: color-mix(in srgb, #E8C24A 10%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-chalk-yellow) 10%, transparent);
    }
  }
  .bg-ink {
    background-color: var(--color-ink);
  }
  .bg-paper {
    background-color: var(--color-paper);
  }
  .bg-paper-warm {
    background-color: var(--color-paper-warm);
  }
  .bg-paper\/92 {
    background-color: color-mix(in srgb, #F1E9D2 92%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-paper) 92%, transparent);
    }
  }
  .bg-teacher-red {
    background-color: var(--color-teacher-red);
  }
  .bg-transparent {
    background-color: transparent;
  }
  .bg-white {
    background-color: var(--color-white);
  }
  .bg-white\/5 {
    background-color: color-mix(in srgb, #fff 5%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-white) 5%, transparent);
    }
  }
  .bg-white\/10 {
    background-color: color-mix(in srgb, #fff 10%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-white) 10%, transparent);
    }
  }
  .bg-\[repeating-linear-gradient\(135deg\,rgba\(255\,255\,255\,0\.04\)_0_18px\,rgba\(255\,255\,255\,0\.08\)_18px_36px\)\] {
    background-image: repeating-linear-gradient(135deg,rgba(255,255,255,0.04) 0 18px,rgba(255,255,255,0.08) 18px 36px);
  }
  .object-cover {
    object-fit: cover;
  }
  .p-2 {
    padding: calc(var(--spacing) * 2);
  }
  .p-3\.5 {
    padding: calc(var(--spacing) * 3.5);
  }
  .p-4 {
    padding: calc(var(--spacing) * 4);
  }
  .p-6 {
    padding: calc(var(--spacing) * 6);
  }
  .p-7 {
    padding: calc(var(--spacing) * 7);
  }
  .p-8 {
    padding: calc(var(--spacing) * 8);
  }
  .p-10 {
    padding: calc(var(--spacing) * 10);
  }
  .p-12 {
    padding: calc(var(--spacing) * 12);
  }
  .p-14 {
    padding: calc(var(--spacing) * 14);
  }
  .p-\[18px\] {
    padding: 18px;
  }
  .p-\[20px_22px\] {
    padding: 20px 22px;
  }
  .\!px-4 {
    padding-inline: calc(var(--spacing) * 4) !important;
  }
  .\!px-8 {
    padding-inline: calc(var(--spacing) * 8) !important;
  }
  .\!px-\[16px\] {
    padding-inline: 16px !important;
  }
  .px-2 {
    padding-inline: calc(var(--spacing) * 2);
  }
  .px-3 {
    padding-inline: calc(var(--spacing) * 3);
  }
  .px-4 {
    padding-inline: calc(var(--spacing) * 4);
  }
  .px-6 {
    padding-inline: calc(var(--spacing) * 6);
  }
  .px-7 {
    padding-inline: calc(var(--spacing) * 7);
  }
  .px-8 {
    padding-inline: calc(var(--spacing) * 8);
  }
  .px-10 {
    padding-inline: calc(var(--spacing) * 10);
  }
  .\!py-2 {
    padding-block: calc(var(--spacing) * 2) !important;
  }
  .\!py-\[10px\] {
    padding-block: 10px !important;
  }
  .py-1\.5 {
    padding-block: calc(var(--spacing) * 1.5);
  }
  .py-2 {
    padding-block: calc(var(--spacing) * 2);
  }
  .py-2\.5 {
    padding-block: calc(var(--spacing) * 2.5);
  }
  .py-3 {
    padding-block: calc(var(--spacing) * 3);
  }
  .py-3\.5 {
    padding-block: calc(var(--spacing) * 3.5);
  }
  .py-5 {
    padding-block: calc(var(--spacing) * 5);
  }
  .py-8 {
    padding-block: calc(var(--spacing) * 8);
  }
  .py-14 {
    padding-block: calc(var(--spacing) * 14);
  }
  .py-16 {
    padding-block: calc(var(--spacing) * 16);
  }
  .pt-1 {
    padding-top: calc(var(--spacing) * 1);
  }
  .pt-2 {
    padding-top: calc(var(--spacing) * 2);
  }
  .pt-2\.5 {
    padding-top: calc(var(--spacing) * 2.5);
  }
  .pt-4 {
    padding-top: calc(var(--spacing) * 4);
  }
  .pt-6 {
    padding-top: calc(var(--spacing) * 6);
  }
  .pt-8 {
    padding-top: calc(var(--spacing) * 8);
  }
  .pt-10 {
    padding-top: calc(var(--spacing) * 10);
  }
  .pt-14 {
    padding-top: calc(var(--spacing) * 14);
  }
  .pt-20 {
    padding-top: calc(var(--spacing) * 20);
  }
  .pt-\[14px\] {
    padding-top: 14px;
  }
  .pr-0 {
    padding-right: calc(var(--spacing) * 0);
  }
  .pr-3 {
    padding-right: calc(var(--spacing) * 3);
  }
  .pr-8 {
    padding-right: calc(var(--spacing) * 8);
  }
  .pb-2 {
    padding-bottom: calc(var(--spacing) * 2);
  }
  .pb-3 {
    padding-bottom: calc(var(--spacing) * 3);
  }
  .pb-6 {
    padding-bottom: calc(var(--spacing) * 6);
  }
  .pb-8 {
    padding-bottom: calc(var(--spacing) * 8);
  }
  .pb-12 {
    padding-bottom: calc(var(--spacing) * 12);
  }
  .pb-16 {
    padding-bottom: calc(var(--spacing) * 16);
  }
  .pb-20 {
    padding-bottom: calc(var(--spacing) * 20);
  }
  .pb-24 {
    padding-bottom: calc(var(--spacing) * 24);
  }
  .pl-3 {
    padding-left: calc(var(--spacing) * 3);
  }
  .pl-3\.5 {
    padding-left: calc(var(--spacing) * 3.5);
  }
  .text-center {
    text-align: center;
  }
  .text-left {
    text-align: left;
  }
  .text-right {
    text-align: right;
  }
  .font-display {
    font-family: var(--font-display);
  }
  .font-mono {
    font-family: var(--font-mono);
  }
  .font-sans {
    font-family: var(--font-sans);
  }
  .font-serif {
    font-family: var(--font-serif);
  }
  .text-2xl {
    font-size: var(--text-2xl);
    line-height: var(--tw-leading, var(--text-2xl--line-height));
  }
  .text-3xl {
    font-size: var(--text-3xl);
    line-height: var(--tw-leading, var(--text-3xl--line-height));
  }
  .text-4xl {
    font-size: var(--text-4xl);
    line-height: var(--tw-leading, var(--text-4xl--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-\[11px\] {
    font-size: 11px !important;
  }
  .\!text-\[13px\] {
    font-size: 13px !important;
  }
  .text-\[9px\] {
    font-size: 9px;
  }
  .text-\[10px\] {
    font-size: 10px;
  }
  .text-\[11px\] {
    font-size: 11px;
  }
  .text-\[12px\] {
    font-size: 12px;
  }
  .text-\[13px\] {
    font-size: 13px;
  }
  .text-\[14px\] {
    font-size: 14px;
  }
  .text-\[15px\] {
    font-size: 15px;
  }
  .text-\[18px\] {
    font-size: 18px;
  }
  .text-\[20px\] {
    font-size: 20px;
  }
  .text-\[22px\] {
    font-size: 22px;
  }
  .text-\[32px\] {
    font-size: 32px;
  }
  .text-\[44px\] {
    font-size: 44px;
  }
  .text-\[clamp\(22px\,2\.6vw\,34px\)\] {
    font-size: clamp(22px, 2.6vw, 34px);
  }
  .text-\[clamp\(28px\,3vw\,40px\)\] {
    font-size: clamp(28px, 3vw, 40px);
  }
  .text-\[clamp\(34px\,3\.6vw\,52px\)\] {
    font-size: clamp(34px, 3.6vw, 52px);
  }
  .text-\[clamp\(36px\,4\.4vw\,64px\)\] {
    font-size: clamp(36px, 4.4vw, 64px);
  }
  .text-\[clamp\(36px\,4vw\,60px\)\] {
    font-size: clamp(36px, 4vw, 60px);
  }
  .text-\[clamp\(36px\,5vw\,72px\)\] {
    font-size: clamp(36px, 5vw, 72px);
  }
  .text-\[clamp\(40px\,5vw\,72px\)\] {
    font-size: clamp(40px, 5vw, 72px);
  }
  .text-\[clamp\(48px\,6vw\,96px\)\] {
    font-size: clamp(48px, 6vw, 96px);
  }
  .text-\[clamp\(56px\,7\.4vw\,116px\)\] {
    font-size: clamp(56px, 7.4vw, 116px);
  }
  .leading-\[0\.95\] {
    --tw-leading: 0.95;
    line-height: 0.95;
  }
  .leading-\[0\.98\] {
    --tw-leading: 0.98;
    line-height: 0.98;
  }
  .leading-\[1\.1\] {
    --tw-leading: 1.1;
    line-height: 1.1;
  }
  .leading-\[1\.02\] {
    --tw-leading: 1.02;
    line-height: 1.02;
  }
  .leading-\[1\.2\] {
    --tw-leading: 1.2;
    line-height: 1.2;
  }
  .leading-\[1\.3\] {
    --tw-leading: 1.3;
    line-height: 1.3;
  }
  .leading-\[1\.4\] {
    --tw-leading: 1.4;
    line-height: 1.4;
  }
  .leading-\[1\.05\] {
    --tw-leading: 1.05;
    line-height: 1.05;
  }
  .leading-\[1\.5\] {
    --tw-leading: 1.5;
    line-height: 1.5;
  }
  .leading-\[1\.6\] {
    --tw-leading: 1.6;
    line-height: 1.6;
  }
  .leading-\[1\.7\] {
    --tw-leading: 1.7;
    line-height: 1.7;
  }
  .leading-\[1\.45\] {
    --tw-leading: 1.45;
    line-height: 1.45;
  }
  .leading-\[1\.55\] {
    --tw-leading: 1.55;
    line-height: 1.55;
  }
  .leading-\[1\.65\] {
    --tw-leading: 1.65;
    line-height: 1.65;
  }
  .leading-none {
    --tw-leading: 1;
    line-height: 1;
  }
  .leading-relaxed {
    --tw-leading: var(--leading-relaxed);
    line-height: var(--leading-relaxed);
  }
  .leading-snug {
    --tw-leading: var(--leading-snug);
    line-height: var(--leading-snug);
  }
  .leading-tight {
    --tw-leading: var(--leading-tight);
    line-height: var(--leading-tight);
  }
  .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-medium {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }
  .font-normal {
    --tw-font-weight: var(--font-weight-normal);
    font-weight: var(--font-weight-normal);
  }
  .font-semibold {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }
  .tracking-\[0\.1em\] {
    --tw-tracking: 0.1em;
    letter-spacing: 0.1em;
  }
  .tracking-\[0\.02em\] {
    --tw-tracking: 0.02em;
    letter-spacing: 0.02em;
  }
  .tracking-\[0\.04em\] {
    --tw-tracking: 0.04em;
    letter-spacing: 0.04em;
  }
  .tracking-\[0\.06em\] {
    --tw-tracking: 0.06em;
    letter-spacing: 0.06em;
  }
  .tracking-\[0\.08em\] {
    --tw-tracking: 0.08em;
    letter-spacing: 0.08em;
  }
  .tracking-\[0\.12em\] {
    --tw-tracking: 0.12em;
    letter-spacing: 0.12em;
  }
  .tracking-\[0\.14em\] {
    --tw-tracking: 0.14em;
    letter-spacing: 0.14em;
  }
  .tracking-\[0\.16em\] {
    --tw-tracking: 0.16em;
    letter-spacing: 0.16em;
  }
  .tracking-\[0\.18em\] {
    --tw-tracking: 0.18em;
    letter-spacing: 0.18em;
  }
  .tracking-normal {
    --tw-tracking: var(--tracking-normal);
    letter-spacing: var(--tracking-normal);
  }
  .tracking-tight {
    --tw-tracking: var(--tracking-tight);
    letter-spacing: var(--tracking-tight);
  }
  .tracking-tighter {
    --tw-tracking: var(--tracking-tighter);
    letter-spacing: var(--tracking-tighter);
  }
  .tracking-wider {
    --tw-tracking: var(--tracking-wider);
    letter-spacing: var(--tracking-wider);
  }
  .tracking-widest {
    --tw-tracking: var(--tracking-widest);
    letter-spacing: var(--tracking-widest);
  }
  .whitespace-nowrap {
    white-space: nowrap;
  }
  .\!text-chalk-yellow {
    color: var(--color-chalk-yellow) !important;
  }
  .\!text-chalk\/60 {
    color: color-mix(in srgb, #F4EFE3 60%, transparent) !important;
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-chalk) 60%, transparent) !important;
    }
  }
  .\!text-chalk\/70 {
    color: color-mix(in srgb, #F4EFE3 70%, transparent) !important;
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-chalk) 70%, transparent) !important;
    }
  }
  .\!text-ink {
    color: var(--color-ink) !important;
  }
  .text-\[\#1A1A1A\] {
    color: #1A1A1A;
  }
  .text-\[\#2c7a4b\] {
    color: #2c7a4b;
  }
  .text-\[\#7B8B7C\] {
    color: #7B8B7C;
  }
  .text-chalk {
    color: var(--color-chalk);
  }
  .text-chalk-yellow {
    color: var(--color-chalk-yellow);
  }
  .text-chalk\/50 {
    color: color-mix(in srgb, #F4EFE3 50%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-chalk) 50%, transparent);
    }
  }
  .text-chalk\/60 {
    color: color-mix(in srgb, #F4EFE3 60%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-chalk) 60%, transparent);
    }
  }
  .text-chalk\/70 {
    color: color-mix(in srgb, #F4EFE3 70%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-chalk) 70%, transparent);
    }
  }
  .text-chalk\/80 {
    color: color-mix(in srgb, #F4EFE3 80%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-chalk) 80%, transparent);
    }
  }
  .text-chalk\/85 {
    color: color-mix(in srgb, #F4EFE3 85%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-chalk) 85%, transparent);
    }
  }
  .text-chalk\/90 {
    color: color-mix(in srgb, #F4EFE3 90%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-chalk) 90%, transparent);
    }
  }
  .text-ink {
    color: var(--color-ink);
  }
  .text-ink-mute {
    color: var(--color-ink-mute);
  }
  .text-ink-soft {
    color: var(--color-ink-soft);
  }
  .text-line {
    color: var(--color-line);
  }
  .text-paper {
    color: var(--color-paper);
  }
  .text-red-400 {
    color: var(--color-red-400);
  }
  .text-teacher-red {
    color: var(--color-teacher-red);
  }
  .text-white {
    color: var(--color-white);
  }
  .text-white\/40 {
    color: color-mix(in srgb, #fff 40%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-white) 40%, transparent);
    }
  }
  .text-white\/45 {
    color: color-mix(in srgb, #fff 45%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-white) 45%, transparent);
    }
  }
  .text-white\/50 {
    color: color-mix(in srgb, #fff 50%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-white) 50%, transparent);
    }
  }
  .text-white\/65 {
    color: color-mix(in srgb, #fff 65%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-white) 65%, transparent);
    }
  }
  .text-white\/80 {
    color: color-mix(in srgb, #fff 80%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-white) 80%, transparent);
    }
  }
  .lowercase {
    text-transform: lowercase;
  }
  .uppercase {
    text-transform: uppercase;
  }
  .italic {
    font-style: italic;
  }
  .no-underline {
    text-decoration-line: none;
  }
  .underline {
    text-decoration-line: underline;
  }
  .underline-offset-2 {
    text-underline-offset: 2px;
  }
  .antialiased {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  .opacity-30 {
    opacity: 30%;
  }
  .opacity-40 {
    opacity: 40%;
  }
  .opacity-50 {
    opacity: 50%;
  }
  .opacity-60 {
    opacity: 60%;
  }
  .opacity-70 {
    opacity: 70%;
  }
  .opacity-80 {
    opacity: 80%;
  }
  .opacity-85 {
    opacity: 85%;
  }
  .opacity-100 {
    opacity: 100%;
  }
  .shadow-\[0_0_0_0_rgba\(232\,194\,74\,0\.6\)\] {
    --tw-shadow: 0 0 0 0 var(--tw-shadow-color, rgba(232,194,74,0.6));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-\[0_1px_3px_rgba\(0\,0\,0\,0\.08\)\] {
    --tw-shadow: 0 1px 3px var(--tw-shadow-color, rgba(0,0,0,0.08));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-\[0_2px_8px_rgba\(80\,50\,10\,0\.06\)\] {
    --tw-shadow: 0 2px 8px var(--tw-shadow-color, rgba(80,50,10,0.06));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-\[4px_4px_0_var\(--color-ink\)\] {
    --tw-shadow: 4px 4px 0 var(--tw-shadow-color, var(--color-ink));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-\[6px_6px_0_var\(--color-ink\)\] {
    --tw-shadow: 6px 6px 0 var(--tw-shadow-color, var(--color-ink));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-\[8px_8px_0_var\(--color-ink\)\] {
    --tw-shadow: 8px 8px 0 var(--tw-shadow-color, var(--color-ink));
    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);
  }
  .blur {
    --tw-blur: blur(8px);
    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,);
  }
  .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,);
  }
  .backdrop-blur-md {
    --tw-backdrop-blur: blur(var(--blur-md));
    -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,);
  }
  .backdrop-saturate-140 {
    --tw-backdrop-saturate: saturate(140%);
    -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));
  }
  .transition-colors {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .duration-200 {
    --tw-duration: 200ms;
    transition-duration: 200ms;
  }
  .duration-500 {
    --tw-duration: 500ms;
    transition-duration: 500ms;
  }
  .duration-700 {
    --tw-duration: 700ms;
    transition-duration: 700ms;
  }
  .outline-none {
    --tw-outline-style: none;
    outline-style: none;
  }
  .select-none {
    -webkit-user-select: none;
    user-select: none;
  }
  .group-hover\:text-teacher-red {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        color: var(--color-teacher-red);
      }
    }
  }
  .after\:absolute {
    &::after {
      content: var(--tw-content);
      position: absolute;
    }
  }
  .after\:inset-\[3px\] {
    &::after {
      content: var(--tw-content);
      inset: 3px;
    }
  }
  .after\:border {
    &::after {
      content: var(--tw-content);
      border-style: var(--tw-border-style);
      border-width: 1px;
    }
  }
  .after\:border-ink {
    &::after {
      content: var(--tw-content);
      border-color: var(--color-ink);
    }
  }
  .after\:border-white {
    &::after {
      content: var(--tw-content);
      border-color: var(--color-white);
    }
  }
  .after\:content-\[\'\'\] {
    &::after {
      --tw-content: '';
      content: var(--tw-content);
    }
  }
  .hover\:border-teacher-red\/35 {
    &:hover {
      @media (hover: hover) {
        border-color: color-mix(in srgb, #C73E2C 35%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          border-color: color-mix(in oklab, var(--color-teacher-red) 35%, transparent);
        }
      }
    }
  }
  .hover\:text-teacher-red {
    &:hover {
      @media (hover: hover) {
        color: var(--color-teacher-red);
      }
    }
  }
  .hover\:text-teacher-red\/80 {
    &:hover {
      @media (hover: hover) {
        color: color-mix(in srgb, #C73E2C 80%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          color: color-mix(in oklab, var(--color-teacher-red) 80%, transparent);
        }
      }
    }
  }
  .hover\:text-white {
    &:hover {
      @media (hover: hover) {
        color: var(--color-white);
      }
    }
  }
  .hover\:no-underline {
    &:hover {
      @media (hover: hover) {
        text-decoration-line: none;
      }
    }
  }
  .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);
      }
    }
  }
  .md\:col-span-2 {
    @media (width >= 48rem) {
      grid-column: span 2 / span 2;
    }
  }
  .md\:grid-cols-2 {
    @media (width >= 48rem) {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }
  .md\:grid-cols-3 {
    @media (width >= 48rem) {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }
  .md\:grid-cols-\[1\.4fr_1fr\] {
    @media (width >= 48rem) {
      grid-template-columns: 1.4fr 1fr;
    }
  }
  .md\:grid-cols-\[2fr_1fr_1fr_1fr\] {
    @media (width >= 48rem) {
      grid-template-columns: 2fr 1fr 1fr 1fr;
    }
  }
  .md\:grid-cols-\[auto_1fr\] {
    @media (width >= 48rem) {
      grid-template-columns: auto 1fr;
    }
  }
  .md\:p-12 {
    @media (width >= 48rem) {
      padding: calc(var(--spacing) * 12);
    }
  }
  .md\:text-\[38px\] {
    @media (width >= 48rem) {
      font-size: 38px;
    }
  }
  .lg\:grid-cols-4 {
    @media (width >= 64rem) {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }
  .lg\:grid-cols-\[1\.1fr_1fr\] {
    @media (width >= 64rem) {
      grid-template-columns: 1.1fr 1fr;
    }
  }
  .lg\:grid-cols-\[1\.2fr_1fr\] {
    @media (width >= 64rem) {
      grid-template-columns: 1.2fr 1fr;
    }
  }
  .lg\:grid-cols-\[1\.05fr_1fr\] {
    @media (width >= 64rem) {
      grid-template-columns: 1.05fr 1fr;
    }
  }
  .lg\:grid-cols-\[2fr_1fr\] {
    @media (width >= 64rem) {
      grid-template-columns: 2fr 1fr;
    }
  }
  .lg\:border-t-0 {
    @media (width >= 64rem) {
      border-top-style: var(--tw-border-style);
      border-top-width: 0px;
    }
  }
  .lg\:border-r {
    @media (width >= 64rem) {
      border-right-style: var(--tw-border-style);
      border-right-width: 1px;
    }
  }
  .lg\:border-b-0 {
    @media (width >= 64rem) {
      border-bottom-style: var(--tw-border-style);
      border-bottom-width: 0px;
    }
  }
  .lg\:border-l-2 {
    @media (width >= 64rem) {
      border-left-style: var(--tw-border-style);
      border-left-width: 2px;
    }
  }
  .lg\:border-dashed {
    @media (width >= 64rem) {
      --tw-border-style: dashed;
      border-style: dashed;
    }
  }
  .lg\:border-white\/10 {
    @media (width >= 64rem) {
      border-color: color-mix(in srgb, #fff 10%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        border-color: color-mix(in oklab, var(--color-white) 10%, transparent);
      }
    }
  }
  .lg\:pt-0 {
    @media (width >= 64rem) {
      padding-top: calc(var(--spacing) * 0);
    }
  }
  .lg\:pr-10 {
    @media (width >= 64rem) {
      padding-right: calc(var(--spacing) * 10);
    }
  }
  .lg\:pl-6 {
    @media (width >= 64rem) {
      padding-left: calc(var(--spacing) * 6);
    }
  }
  .lg\:pl-12 {
    @media (width >= 64rem) {
      padding-left: calc(var(--spacing) * 12);
    }
  }
  .lg\:text-\[22px\] {
    @media (width >= 64rem) {
      font-size: 22px;
    }
  }
}
@font-face {
  font-family: 'Caveat';
  font-style: normal;
  font-weight: 400;
  src: url('/fonts/caveat-v23-latin-regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Caveat';
  font-style: normal;
  font-weight: 700;
  src: url('/fonts/caveat-v23-latin-700.woff2') format('woff2');
}
@font-face {
  font-family: 'Kalam';
  font-style: normal;
  font-weight: 400;
  src: url('/fonts/kalam-v18-latin-regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Bebas Neue';
  font-style: normal;
  font-weight: 400;
  src: url('/fonts/bebas-neue-v16-latin-regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 400;
  src: url('/fonts/oswald-v57-latin-regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  src: url('/fonts/inter-v20-latin-regular.woff2') format('woff2');
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  src: url('/fonts/jetbrains-mono-v24-latin-regular.woff2') format('woff2');
}
@layer base {
  :root {
    --serif: var(--font-serif);
    --display: var(--font-display);
    --sans: var(--font-sans);
    --mono: var(--font-mono);
    --board: var(--color-board);
    --board-deep: var(--color-board-deep);
    --chalk: var(--color-chalk);
    --chalk-yellow: var(--color-chalk-yellow);
    --teacher-red: var(--color-teacher-red);
    --paper: var(--color-paper);
    --paper-warm: var(--color-paper-warm);
    --ink: var(--color-ink);
    --ink-soft: var(--color-ink-soft);
    --ink-mute: var(--color-ink-mute);
    --line: var(--color-line);
    --chalk-line: rgba(244, 239, 227, 0.18);
    --chalk-soft: rgba(244, 239, 227, 0.45);
    --chalk-mute: rgba(244, 239, 227, 0.7);
    --chalk-faint: rgba(244, 239, 227, 0.08);
  }
  a {
    text-decoration: underline;
    text-underline-offset: 2px;
  }
  a, button, [role="button"] {
    cursor: pointer;
  }
  a:disabled, button:disabled, [role="button"]:disabled, .disabled {
    cursor: not-allowed;
  }
  a.no-underline, .btn, .btn-primary, .btn-ghost, .btn-chalk, .btn-dark {
    text-decoration: none;
  }
  body {
    background-color: var(--color-paper);
    color: var(--color-ink);
    font-family: var(--font-sans);
    -webkit-font-smoothing: antialiased;
    background-image: radial-gradient(circle at 12% 18%, rgba(120,90,30,0.07), transparent 40%), radial-gradient(circle at 88% 76%, rgba(120,90,30,0.05), transparent 40%), repeating-linear-gradient(0deg, transparent 0 27px, rgba(180, 100, 110, 0.05) 27px 28px);
  }
}
@layer components {
  .board {
    background-color: var(--color-board);
    color: var(--color-chalk);
    border: 14px solid #5A3A1E;
    border-radius: 0.5rem;
    position: relative;
    box-shadow: inset 0 0 0 2px #3D2710, inset 0 0 60px rgba(0,0,0,0.4), 0 12px 30px rgba(40, 25, 5, 0.25);
    background-image: radial-gradient(ellipse at 30% 30%, rgba(244,239,227,0.04), transparent 60%), radial-gradient(ellipse at 70% 70%, rgba(244,239,227,0.03), transparent 60%);
  }
  .board::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -4px;
    height: 0.5rem;
    pointer-events: none;
    filter: blur(2px);
    background: linear-gradient(180deg, transparent, rgba(244,239,227,0.18));
  }
  .card {
    background-color: #FBF5E2;
    border: 1px solid var(--color-line);
    border-radius: 0.375rem;
    position: relative;
    box-shadow: 0 1px 0 var(--color-paper-warm), 0 4px 16px rgba(80, 50, 10, 0.06);
  }
  .card-lined {
    background-color: #FBF5E2;
    border: 1px solid var(--color-line);
    border-radius: 0.375rem;
    position: relative;
    box-shadow: 0 1px 0 var(--color-paper-warm), 0 4px 16px rgba(80, 50, 10, 0.06);
    background-image: repeating-linear-gradient( 180deg, transparent 0 26px, rgba(70, 40, 80, 0.08) 26px 27px );
    background-position: 0 24px;
  }
  .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.875rem 1.375rem;
    border-radius: 0.25rem;
    border: 1px solid transparent;
    font-weight: 700;
    font-size: 13px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    transition: all 0.2s;
  }
  .btn:active {
    transform: translateY(1px);
  }
  .btn-primary {
    background-color: var(--color-teacher-red);
    color: white;
    border-color: var(--color-teacher-red);
    box-shadow: 0 2px 0 #8E2A1E;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.875rem 1.375rem;
    border-radius: 0.25rem;
    font-weight: 700;
    font-size: 13px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    transition: all 0.2s;
  }
  .btn-primary:hover {
    background-color: #B0341F;
  }
  .btn-ghost {
    background-color: transparent;
    color: var(--color-ink);
    border: 1px solid var(--color-ink);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.875rem 1.375rem;
    border-radius: 0.25rem;
    font-weight: 700;
    font-size: 13px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    transition: all 0.2s;
  }
  .btn-ghost:hover {
    background-color: var(--color-ink);
    color: var(--color-paper);
  }
  .btn-chalk {
    background-color: rgba(255,255,255,0.06);
    color: var(--color-chalk);
    border: 1.5px dashed var(--color-chalk);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.875rem 1.375rem;
    border-radius: 0.25rem;
    font-family: var(--font-serif);
    font-weight: 700;
    font-size: 1.125rem;
    transition: all 0.2s;
  }
  .btn-chalk:hover {
    background-color: rgba(255,255,255,0.18);
  }
  .btn-dark {
    background-color: var(--color-ink);
    color: var(--color-paper);
    border: 1px solid var(--color-ink);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.875rem 1.375rem;
    border-radius: 0.25rem;
    font-weight: 700;
    font-size: 13px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    transition: all 0.2s;
  }
  .btn-dark:hover {
    background-color: black;
  }
  .h-chalk {
    font-family: var(--font-serif);
    font-weight: 700;
    line-height: 1;
    color: var(--color-chalk);
    text-shadow: 0 0 1px rgba(244,239,227,0.3);
  }
  .eyebrow {
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-weight: 500;
    color: var(--color-teacher-red);
  }
  .ticket {
    display: grid;
    grid-template-columns: 1fr 200px;
    background-color: #FBF5E2;
    border: 2px solid var(--color-ink);
    border-radius: 0.375rem;
    overflow: hidden;
    position: relative;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    max-width: 48rem;
    margin-left: auto;
    margin-right: auto;
  }
  .ticket-body {
    padding: 2rem;
    position: relative;
  }
  .ticket-stub {
    background-color: var(--color-paper-warm);
    border-left: 1.5px dashed var(--color-ink);
    padding: 1.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    align-items: center;
    justify-content: center;
    text-align: center;
  }
  .ticket-row {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
    border-top: 1px dashed var(--color-line);
  }
  .ticket-row:first-child {
    border-top: 0;
    padding-top: 0;
  }
  .ticket-row .k {
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-ink-mute);
  }
  .ticket-row .v {
    font-family: var(--font-serif);
    font-size: 1.375rem;
    font-weight: 700;
    color: var(--color-ink);
    line-height: 1.1;
  }
  .stamp {
    width: 4rem;
    height: 4rem;
    border: 2px solid var(--color-teacher-red);
    border-radius: 9999px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-display);
    font-size: 1.125rem;
    color: var(--color-teacher-red);
    letter-spacing: 0.1em;
    transform: rotate(-6deg);
    position: relative;
  }
  .stamp::after {
    content: "";
    position: absolute;
    inset: 0.25rem;
    border: 1px dashed var(--color-teacher-red);
    border-radius: 9999px;
  }
  .stamp small {
    display: block;
    font-size: 8px;
    letter-spacing: 0.18em;
    margin-top: -2px;
  }
  .legal-prose h2 {
    font-family: var(--font-display);
    text-transform: uppercase;
    font-size: clamp(28px, 3vw, 40px);
    line-height: 1.05;
    margin: 56px 0 16px;
    color: var(--color-ink);
    padding-bottom: 12px;
    border-bottom: 2px solid var(--color-ink);
  }
  .legal-prose h2:first-child {
    margin-top: 0;
  }
  .legal-prose h3 {
    font-family: var(--font-display);
    text-transform: uppercase;
    font-size: 20px;
    letter-spacing: 0.02em;
    margin: 36px 0 10px;
    color: var(--color-ink);
  }
  .legal-prose h4 {
    font-family: var(--font-mono);
    text-transform: uppercase;
    font-size: 11px;
    letter-spacing: 0.16em;
    margin: 28px 0 8px;
    color: var(--color-teacher-red);
  }
  .legal-prose p, .legal-prose li {
    font-size: 16px;
    line-height: 1.7;
    color: var(--color-ink-soft);
    margin: 0 0 14px;
  }
  .legal-prose ul {
    padding-left: 24px;
    margin: 0 0 18px;
    list-style: disc;
  }
  .legal-prose a {
    color: var(--color-teacher-red);
  }
  .legal-prose a:hover {
    color: var(--color-ink);
  }
  .tag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-ink-mute);
    padding: 4px 9px;
    border: 1px solid var(--color-line);
    border-radius: 4px;
    background: transparent;
    font-weight: 500;
  }
  .tag.red {
    color: var(--color-teacher-red);
    border-color: rgba(199,62,44,0.35);
  }
  .tag-beispiel {
    display: inline-block;
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #fff;
    padding: 6px 12px;
    border: 1px solid var(--color-teacher-red);
    border-radius: 4px;
    background: var(--color-teacher-red);
    font-weight: 700;
    text-align: center;
    transition: background-color 0.12s ease;
  }
  .booking-row {
    width: 100%;
    display: grid;
    grid-template-columns: 96px 1fr 100px 140px;
    gap: 0;
    padding: 18px 24px;
    background: transparent;
    border: none;
    border-top: 1px solid var(--color-line);
    text-align: left;
    cursor: pointer;
    align-items: center;
    transition: background-color 0.12s ease;
  }
  @keyframes eye-catch-shake {
    0% {
      transform: translate(0, 0) rotate(0deg);
    }
    15% {
      transform: translate(-3px, 1.5px) rotate(-1.5deg);
    }
    30% {
      transform: translate(2px, -1px) rotate(2deg);
    }
    45% {
      transform: translate(-1.5px, 2px) rotate(-1deg);
    }
    60% {
      transform: translate(3px, 1px) rotate(1.5deg);
    }
    75% {
      transform: translate(-2px, -1.5px) rotate(-2deg);
    }
    90% {
      transform: translate(1.5px, -1px) rotate(1deg);
    }
    100% {
      transform: translate(0, 0) rotate(0deg);
    }
  }
  .booking-row:hover {
    background: var(--color-paper-warm);
  }
  .booking-row:hover .tag {
    background: var(--color-teacher-red) !important;
    color: #fff !important;
    border-color: var(--color-teacher-red) !important;
    animation: eye-catch-shake 0.1s ease-in-out 3;
  }
  .booking-row:hover .tag-beispiel {
    animation: eye-catch-shake 0.1s ease-in-out 3;
  }
  .field {
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
  }
  .field label {
    font-size: 11px;
    font-weight: 700;
    color: var(--color-ink);
    letter-spacing: 0.1em;
    text-transform: uppercase;
  }
  .field label .opt {
    color: var(--color-ink-mute);
    font-weight: 400;
    margin-left: 4px;
    text-transform: none;
    letter-spacing: 0;
    font-size: 11px;
  }
  .field input, .field select, .field textarea {
    font-family: var(--font-sans);
    font-size: 15px;
    color: var(--color-ink);
    background-color: white;
    border: 1.5px solid var(--color-ink);
    border-radius: 0.25rem;
    padding: 0.75rem 0.875rem;
    outline: none;
    transition: all 0.2s;
  }
  .field input:focus, .field select:focus, .field textarea:focus {
    border-color: var(--color-teacher-red);
    box-shadow: 0 0 0 3px rgba(199,62,44,0.12);
  }
  .field .hint {
    font-size: 12px;
    color: var(--color-ink-mute);
  }
  .field .err {
    font-size: 12px;
    color: var(--color-teacher-red);
    display: flex;
    align-items: center;
    gap: 6px;
    font-weight: 500;
  }
  .field input.field-error, .field textarea.field-error {
    border-color: var(--color-teacher-red);
    box-shadow: 0 0 0 3px rgba(199,62,44,0.12);
  }
  .stepper {
    display: inline-flex;
    align-items: center;
    border: 1.5px solid var(--color-ink);
    border-radius: 4px;
    background: white;
    overflow: hidden;
  }
  .stepper button {
    width: 44px;
    height: 44px;
    background: transparent;
    border: none;
    color: var(--color-ink);
    font-size: 18px;
    cursor: pointer;
  }
  .stepper button:hover {
    background: rgba(0,0,0,0.05);
  }
  .stepper input {
    width: 64px;
    text-align: center;
    border: none;
    border-left: 1.5px solid var(--color-ink);
    border-right: 1.5px solid var(--color-ink);
    font-family: var(--font-mono);
    font-size: 16px;
    padding: 0;
    height: 44px;
    outline: none;
    background: transparent;
  }
  .steps {
    display: flex;
    align-items: center;
    gap: 12px;
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-ink-mute);
    font-weight: 500;
  }
  .steps .step {
    display: inline-flex;
    align-items: center;
    gap: 8px;
  }
  .steps .step .num {
    width: 22px;
    height: 22px;
    border: 1.5px solid var(--color-line);
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    flex-shrink: 0;
  }
  .steps .step.active {
    color: var(--color-teacher-red);
  }
  .steps .step.active .num {
    border-color: var(--color-teacher-red);
    background: var(--color-teacher-red);
    color: #fff;
  }
  .steps .step.done {
    color: var(--color-ink-soft);
  }
  .steps .step.done .num {
    border-color: var(--color-ink-soft);
    color: var(--color-ink-soft);
  }
  .steps .sep {
    width: 24px;
    height: 1px;
    background: var(--color-line);
    flex-shrink: 0;
  }
  .info-tip {
    padding: 14px 16px;
    background: var(--color-paper);
    border-radius: 10px;
    font-size: 13px;
    color: var(--color-ink-soft);
    display: flex;
    gap: 12px;
    align-items: flex-start;
  }
  .info-tip strong {
    color: var(--color-ink);
  }
  .modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 90;
    background: rgba(15, 14, 13, 0.65);
    backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
  }
  .modal-overlay.hidden {
    display: none;
  }
  .modal {
    background: var(--color-paper);
    border: 2px solid var(--color-ink);
    border-radius: 6px;
    width: 100%;
    max-width: 640px;
    position: relative;
    box-shadow: 0 30px 80px rgba(0,0,0,0.4);
    max-height: 90vh;
    overflow-y: auto;
  }
  .modal-close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 36px;
    height: 36px;
    border-radius: 4px;
    background: var(--color-paper);
    border: 1.5px solid var(--color-ink);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-ink);
    cursor: pointer;
    z-index: 2;
    transition: all .15s ease;
  }
  .modal-close:hover {
    background: var(--color-ink);
    color: var(--color-paper);
  }
  .modal-tab {
    background: none;
    border: none;
    padding: 12px 0;
    margin-right: 28px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 500;
    color: var(--color-ink-mute);
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    cursor: pointer;
    font-family: var(--font-sans);
    transition: color .15s ease, border-color .15s ease;
  }
  .modal-tab.active {
    color: var(--color-teacher-red);
    border-bottom-color: var(--color-teacher-red);
  }
  .modal-tab:hover:not(.active) {
    color: var(--color-ink);
  }
  .timeline {
    position: relative;
    padding: 24px 8px 12px;
  }
  .timeline-track {
    position: relative;
    height: 0;
    border-top: 2px dashed var(--chalk-line);
    margin: 70px 16px 80px;
  }
  .timeline-tick {
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
  }
  .slot-marker {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: var(--board);
    border: 2px solid var(--chalk-line);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-family: var(--serif);
    color: var(--chalk);
    font-size: 17px;
    font-weight: 700;
    cursor: pointer;
    transition: all .2s ease;
    z-index: 2;
  }
  .slot-marker .seats-mini {
    display: grid;
    grid-template-columns: repeat(5, 4px);
    gap: 2px;
    margin-top: 4px;
    justify-content: center;
  }
  .slot-marker .seats-mini i {
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: var(--chalk-yellow);
  }
  .slot-marker .seats-mini i.taken {
    background: var(--chalk-soft);
  }
  .slot-marker:hover {
    border-color: var(--chalk-yellow);
    transform: translate(-50%,-50%) scale(1.05);
  }
  .slot-marker.selected {
    background: var(--chalk-yellow);
    color: var(--ink);
    border-color: var(--chalk);
    border-width: 3px;
    transform: translate(-50%, -50%) scale(1.15);
    box-shadow: 0 0 0 6px rgba(244,239,227,0.25), 0 0 20px rgba(232,194,74,0.6);
  }
  .slot-marker.selected .seats-mini i {
    background: var(--ink);
    opacity: 0.8;
  }
  .slot-marker.full {
    background: transparent;
    color: var(--chalk-soft);
    border-style: dashed;
    cursor: not-allowed;
  }
  .slot-marker.full:hover {
    transform: translate(-50%,-50%);
    border-color: var(--chalk-line);
  }
  .slot-label-above, .slot-label-below {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    text-align: center;
    white-space: nowrap;
    font-family: var(--serif);
    font-size: 16px;
    font-weight: 700;
    color: var(--chalk-mute);
  }
  .slot-label-above {
    bottom: calc(100% + 12px);
  }
  .slot-label-below {
    top: calc(100% + 12px);
    font-size: 14px;
    color: var(--chalk-soft);
  }
  .group-pill {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 22px;
    background: var(--paper);
    border: 2px solid var(--ink);
    border-radius: 999px;
    font-size: 17px;
    font-family: var(--serif);
    font-weight: 700;
    color: var(--ink);
  }
  .group-pill .pill-year {
    font-family: var(--mono);
    font-weight: 700;
    font-size: 14px;
    color: var(--teacher-red);
    letter-spacing: 0.04em;
  }
  .group-pill .pill-pax {
    font-family: var(--mono);
    font-weight: 600;
    font-size: 13.5px;
    color: var(--ink-mute);
    padding-left: 12px;
    border-left: 1.5px solid var(--line);
  }
  .capbar {
    display: block;
    width: 100%;
    height: 6px;
    background: var(--chalk-faint);
    border-radius: 0;
    overflow: hidden;
    position: relative;
  }
  .capbar.light {
    background: var(--paper-warm);
  }
  .capbar i {
    display: block;
    height: 100%;
    background: var(--teacher-red);
    transition: width .4s ease;
  }
  .capbar.full i {
    background: var(--chalk-soft);
  }
  .capbar.dark i {
    background: var(--chalk-yellow);
  }
  .tag.green {
    color: #2F6B43;
    border-color: rgba(47,107,67,0.4);
  }
  .tag.chalk {
    color: var(--chalk);
    border-color: var(--chalk-line);
  }
}
@property --tw-translate-x {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-translate-y {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-translate-z {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-scale-x {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@property --tw-scale-y {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@property --tw-scale-z {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@property --tw-rotate-x {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-y {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-z {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-x {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-y {
  syntax: "*";
  inherits: false;
}
@property --tw-space-y-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-space-x-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-leading {
  syntax: "*";
  inherits: false;
}
@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;
}
@property --tw-duration {
  syntax: "*";
  inherits: false;
}
@property --tw-content {
  syntax: "*";
  initial-value: "";
  inherits: false;
}
@keyframes pulse {
  50% {
    opacity: 0.5;
  }
}
@keyframes bounce {
  0%, 100% {
    transform: translateY(-25%);
    animation-timing-function: cubic-bezier(0.8, 0, 1, 1);
  }
  50% {
    transform: none;
    animation-timing-function: cubic-bezier(0, 0, 0.2, 1);
  }
}
@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-translate-x: 0;
      --tw-translate-y: 0;
      --tw-translate-z: 0;
      --tw-scale-x: 1;
      --tw-scale-y: 1;
      --tw-scale-z: 1;
      --tw-rotate-x: initial;
      --tw-rotate-y: initial;
      --tw-rotate-z: initial;
      --tw-skew-x: initial;
      --tw-skew-y: initial;
      --tw-space-y-reverse: 0;
      --tw-space-x-reverse: 0;
      --tw-border-style: solid;
      --tw-leading: initial;
      --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;
      --tw-duration: initial;
      --tw-content: "";
    }
  }
}
