/* [next]/internal/font/google/geist_a71539c9.module.css [app-client] (css) */
@font-face {
  font-family: Geist;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/fef07dbb0973bf53-s.3p2_lha1f2xer.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: Geist;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/8a480f0b521d4e75-s.1qq4vpdcun5oj.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: Geist;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/53b9e256198e5412-s.390ncx5urfkfu.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: Geist;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/7178b3e590c64307-s.21jp631_3pja2.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: Geist;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/caa3a2e1cccd8315-s.p.0wgildi0cnwt9.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: Geist Fallback;
  src: local(Arial);
  ascent-override: 95.94%;
  descent-override: 28.16%;
  line-gap-override: 0.0%;
  size-adjust: 104.76%;
}

.geist_a71539c9-module__T19VSG__className {
  font-family: Geist, Geist Fallback;
  font-style: normal;
}

.geist_a71539c9-module__T19VSG__variable {
  --font-geist-sans: "Geist", "Geist Fallback";
}

/* [next]/internal/font/google/geist_mono_8d43a2aa.module.css [app-client] (css) */
@font-face {
  font-family: Geist Mono;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/5ce348bf30bf5439-s.31988l_ccedte.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: Geist Mono;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/4fa387ec64143e14-s.2tuy5pz7dlieh.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: Geist Mono;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/6306c77e7c8268e4-s.2dbetqa9o8jxf.woff2") format("woff2");
  unicode-range: U+2000-2001, U+2004-2008, U+200A, U+23B8-23BD, U+2500-259F;
}

@font-face {
  font-family: Geist Mono;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/7d817b4c03b0c5f1-s.1uyisp29ctx0d.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: Geist Mono;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/bbc41e54d2fcbd21-s.1rgnod-3esatf.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: Geist Mono;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/797e433ab948586e-s.p.0r6juujl39pe6.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: Geist Mono Fallback;
  src: local(Arial);
  ascent-override: 74.67%;
  descent-override: 21.92%;
  line-gap-override: 0.0%;
  size-adjust: 134.59%;
}

.geist_mono_8d43a2aa-module__8Li5zG__className {
  font-family: Geist Mono, Geist Mono Fallback;
  font-style: normal;
}

.geist_mono_8d43a2aa-module__8Li5zG__variable {
  --font-geist-mono: "Geist Mono", "Geist Mono Fallback";
}

/* [project]/node_modules/.pnpm/tldraw@5.2.2_@floating-ui+dom@1.7.6_@types+react-dom@19.2.3_@types+react@19.2.17_react-dom@19.2.4_react@19.2.4/node_modules/tldraw/tldraw.css [app-client] (css) */
.tl-container {
  --tl-space-1: 2px;
  --tl-space-2: 4px;
  --tl-space-3: 8px;
  --tl-space-4: 12px;
  --tl-space-5: 16px;
  --tl-space-6: 20px;
  --tl-space-7: 28px;
  --tl-space-8: 32px;
  --tl-space-9: 64px;
  --tl-space-10: 72px;
  --tl-radius-0: 2px;
  --tl-radius-1: 4px;
  --tl-radius-2: 6px;
  --tl-radius-3: 9px;
  --tl-radius-4: 11px;
  --tl-layer-canvas-hidden: -999999;
  --tl-layer-canvas-background: 100;
  --tl-layer-canvas-grid: 150;
  --tl-layer-watermark: 200;
  --tl-layer-canvas-in-front: 250;
  --tl-layer-canvas-shapes: 300;
  --tl-layer-canvas-overlays: 500;
  --tl-layer-canvas-blocker: 10000;
  --tl-layer-overlays-collaborator-scribble: 10;
  --tl-layer-overlays-collaborator-brush: 20;
  --tl-layer-overlays-collaborator-shape-indicator: 30;
  --tl-layer-overlays-user-scribble: 40;
  --tl-layer-overlays-user-brush: 50;
  --tl-layer-overlays-user-snapline: 90;
  --tl-layer-overlays-selection-fg: 100;
  --tl-layer-overlays-user-handles: 105;
  --tl-layer-overlays-user-indicator-hint: 110;
  --tl-layer-overlays-collaborator-cursor-hint: 120;
  --tl-layer-overlays-collaborator-cursor: 130;
  --tl-layer-text-container: 1;
  --tl-layer-text-content: 3;
  --tl-layer-text-editor: 4;
  --tl-layer-error-overlay: 1;
  --tl-layer-error-canvas: 2;
  --tl-layer-error-canvas-after: 3;
  --tl-layer-error-content: 4;
  --tl-zoom: 1;
  --tl-tab-size: 2;
  --tl-cursor-none: none;
  --tl-cursor-default: url("data:image/svg+xml,<svg height='32' width='32' viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg' style='color: black;'><defs><filter id='shadow' y='-40%' x='-40%' width='180px' height='180%' color-interpolation-filters='sRGB'><feDropShadow dx='1' dy='1' stdDeviation='1.2' flood-opacity='.5'/></filter></defs><g fill='none' transform='rotate(0 16 16)' filter='url(%23shadow)'><path d='m12 24.4219v-16.015l11.591 11.619h-6.781l-.411.124z' fill='white'/><path d='m21.0845 25.0962-3.605 1.535-4.682-11.089 3.686-1.553z' fill='white'/><path d='m19.751 24.4155-1.844.774-3.1-7.374 1.841-.775z' fill='black'/><path d='m13 10.814v11.188l2.969-2.866.428-.139h4.768z' fill='black'/></g></svg>")
			12 8,
		default;
  --tl-cursor-pointer: url("data:image/svg+xml,<svg height='32' width='32' viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg' style='color: black;'><defs><filter id='shadow' y='-40%' x='-40%' width='180px' height='180%' color-interpolation-filters='sRGB'><feDropShadow dx='1' dy='1' stdDeviation='1.2' flood-opacity='.5'/></filter></defs><g fill='none' transform='rotate(0 16 16)' filter='url(%23shadow)'><path d='m13.3315 21.3799c-.284-.359-.629-1.093-1.243-1.984-.348-.504-1.211-1.453-1.468-1.935-.223-.426-.199-.617-.146-.97.094-.628.738-1.117 1.425-1.051.519.049.959.392 1.355.716.239.195.533.574.71.788.163.196.203.277.377.509.23.307.302.459.214.121-.071-.496-.187-1.343-.355-2.092-.128-.568-.159-.657-.281-1.093-.129-.464-.195-.789-.316-1.281-.084-.348-.235-1.059-.276-1.459-.057-.547-.087-1.439.264-1.849.275-.321.906-.418 1.297-.22.512.259.803 1.003.936 1.3.239.534.387 1.151.516 1.961.164 1.031.466 2.462.476 2.763.024-.369-.068-1.146-.004-1.5.058-.321.328-.694.666-.795.286-.085.621-.116.916-.055.313.064.643.288.766.499.362.624.369 1.899.384 1.831.086-.376.071-1.229.284-1.584.14-.234.497-.445.687-.479.294-.052.655-.068.964-.008.249.049.586.345.677.487.218.344.342 1.317.379 1.658.015.141.074-.392.293-.736.406-.639 1.843-.763 1.898.639.025.654.02.624.02 1.064 0 .517-.012.828-.04 1.202-.031.4-.117 1.304-.242 1.742-.086.301-.371.978-.652 1.384 0 0-1.074 1.25-1.191 1.813-.118.562-.079.566-.102.965-.023.398.121.922.121.922s-.802.104-1.234.035c-.391-.063-.875-.841-1-1.079-.172-.328-.539-.265-.682-.023-.225.383-.709 1.07-1.051 1.113-.668.084-2.054.031-3.139.02 0 0 .185-1.011-.227-1.358-.305-.259-.83-.784-1.144-1.06z' fill='white'/><g stroke='black' stroke-linecap='round' stroke-width='.75'><path d='m13.3315 21.3799c-.284-.359-.629-1.093-1.243-1.984-.348-.504-1.211-1.453-1.468-1.935-.223-.426-.199-.617-.146-.97.094-.628.738-1.117 1.425-1.051.519.049.959.392 1.355.716.239.195.533.574.71.788.163.196.203.277.377.509.23.307.302.459.214.121-.071-.496-.187-1.343-.355-2.092-.128-.568-.159-.657-.281-1.093-.129-.464-.195-.789-.316-1.281-.084-.348-.235-1.059-.276-1.459-.057-.547-.087-1.439.264-1.849.275-.321.906-.418 1.297-.22.512.259.803 1.003.936 1.3.239.534.387 1.151.516 1.961.164 1.031.466 2.462.476 2.763.024-.369-.068-1.146-.004-1.5.058-.321.328-.694.666-.795.286-.085.621-.116.916-.055.313.064.643.288.766.499.362.624.369 1.899.384 1.831.086-.376.071-1.229.284-1.584.14-.234.497-.445.687-.479.294-.052.655-.068.964-.008.249.049.586.345.677.487.218.344.342 1.317.379 1.658.015.141.074-.392.293-.736.406-.639 1.843-.763 1.898.639.025.654.02.624.02 1.064 0 .517-.012.828-.04 1.202-.031.4-.117 1.304-.242 1.742-.086.301-.371.978-.652 1.384 0 0-1.074 1.25-1.191 1.813-.118.562-.079.566-.102.965-.023.398.121.922.121.922s-.802.104-1.234.035c-.391-.063-.875-.841-1-1.079-.172-.328-.539-.265-.682-.023-.225.383-.709 1.07-1.051 1.113-.668.084-2.054.031-3.139.02 0 0 .185-1.011-.227-1.358-.305-.259-.83-.784-1.144-1.06z' stroke-linejoin='round'/><path d='m21.5664 21.7344v-3.459'/><path d='m19.5508 21.7461-.016-3.473'/><path d='m17.5547 18.3047.021 3.426'/></g></g></svg>")
			14 10,
		pointer;
  --tl-cursor-cross: url("data:image/svg+xml,<svg height='32' width='32' viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg' style='color: black;'><defs><filter id='shadow' y='-40%' x='-40%' width='180px' height='180%' color-interpolation-filters='sRGB'><feDropShadow dx='1' dy='1' stdDeviation='1.2' flood-opacity='.5'/></filter></defs><g fill='none' transform='rotate(0 16 16)' filter='url(%23shadow)'><path d='m25 16h-6.01v-6h-2.98v6h-6.01v3h6.01v6h2.98v-6h6.01z' fill='white'/><path d='m23.9902 17.0103h-6v-6.01h-.98v6.01h-6v.98h6v6.01h.98v-6.01h6z' fill='%23231f1f'/></g></svg>")
			16 16,
		crosshair;
  --tl-cursor-move: url("data:image/svg+xml,<svg height='32' width='32' viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg' style='color: black;'><defs><filter id='shadow' y='-40%' x='-40%' width='180px' height='180%' color-interpolation-filters='sRGB'><feDropShadow dx='1' dy='1' stdDeviation='1.2' flood-opacity='.5'/></filter></defs><g fill='none' transform='rotate(0 16 16)' filter='url(%23shadow)'><path d='m19 14h1v1h-1zm1 6h-1v-1h1zm-5-5h-1v-1h1zm0 5h-1v-1h1zm2-10.987-7.985 7.988 5.222 5.221 2.763 2.763 7.984-7.985z' fill='white'/><g fill='black'><path d='m23.5664 16.9971-2.557-2.809v1.829h-4.009-4.001v-1.829l-2.571 2.809 2.572 2.808-.001-1.808h4.001 4.009l-.001 1.808z'/><path d='m17.9873 17h.013v-4.001l1.807.001-2.807-2.571-2.809 2.57h1.809v4.001h.008v4.002l-1.828-.001 2.807 2.577 2.805-2.576h-1.805z'/></g></g></svg>")
			16 16,
		move;
  --tl-cursor-grab: url("data:image/svg+xml,<svg height='32' width='32' viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg' style='color: black;'><defs><filter id='shadow' y='-40%' x='-40%' width='180px' height='180%' color-interpolation-filters='sRGB'><feDropShadow dx='1' dy='1' stdDeviation='1.2' flood-opacity='.5'/></filter></defs><g fill='none' transform='rotate(0 16 16)' filter='url(%23shadow)'><path d='m13.5557 17.5742c-.098-.375-.196-.847-.406-1.552-.167-.557-.342-.859-.47-1.233-.155-.455-.303-.721-.496-1.181-.139-.329-.364-1.048-.457-1.44-.119-.509.033-.924.244-1.206.253-.339.962-.49 1.357-.351.371.13.744.512.916.788.288.46.357.632.717 1.542.393.992.564 1.918.611 2.231l.085.452c-.001-.04-.043-1.122-.044-1.162-.035-1.029-.06-1.823-.038-2.939.002-.126.064-.587.084-.715.078-.5.305-.8.673-.979.412-.201.926-.215 1.401-.017.423.173.626.55.687 1.022.014.109.094.987.093 1.107-.013 1.025.006 1.641.015 2.174.004.231.003 1.625.017 1.469.061-.656.094-3.189.344-3.942.144-.433.405-.746.794-.929.431-.203 1.113-.07 1.404.243.285.305.446.692.482 1.153.032.405-.019.897-.02 1.245 0 .867-.021 1.324-.037 2.121-.001.038-.015.298.023.182.094-.28.188-.542.266-.745.049-.125.241-.614.359-.859.114-.234.211-.369.415-.688.2-.313.415-.448.668-.561.54-.235 1.109.112 1.301.591.086.215.009.713-.028 1.105-.061.647-.254 1.306-.352 1.648-.128.447-.274 1.235-.34 1.601-.072.394-.234 1.382-.359 1.82-.086.301-.371.978-.652 1.384 0 0-1.074 1.25-1.192 1.812-.117.563-.078.567-.101.965-.024.399.121.923.121.923s-.802.104-1.234.034c-.391-.062-.875-.841-1-1.078-.172-.328-.539-.265-.682-.023-.225.383-.709 1.07-1.051 1.113-.668.084-2.054.03-3.139.02 0 0 .185-1.011-.227-1.358-.305-.26-.83-.784-1.144-1.06l-.832-.921c-.284-.36-.629-1.093-1.243-1.985-.348-.504-1.027-1.085-1.284-1.579-.223-.425-.331-.954-.19-1.325.225-.594.675-.897 1.362-.832.519.05.848.206 1.238.537.225.19.573.534.75.748.163.195.203.276.377.509.23.307.302.459.214.121' fill='white'/><g stroke='black' stroke-linecap='round' stroke-width='.75'><path d='m13.5557 17.5742c-.098-.375-.196-.847-.406-1.552-.167-.557-.342-.859-.47-1.233-.155-.455-.303-.721-.496-1.181-.139-.329-.364-1.048-.457-1.44-.119-.509.033-.924.244-1.206.253-.339.962-.49 1.357-.351.371.13.744.512.916.788.288.46.357.632.717 1.542.393.992.564 1.918.611 2.231l.085.452c-.001-.04-.043-1.122-.044-1.162-.035-1.029-.06-1.823-.038-2.939.002-.126.064-.587.084-.715.078-.5.305-.8.673-.979.412-.201.926-.215 1.401-.017.423.173.626.55.687 1.022.014.109.094.987.093 1.107-.013 1.025.006 1.641.015 2.174.004.231.003 1.625.017 1.469.061-.656.094-3.189.344-3.942.144-.433.405-.746.794-.929.431-.203 1.113-.07 1.404.243.285.305.446.692.482 1.153.032.405-.019.897-.02 1.245 0 .867-.021 1.324-.037 2.121-.001.038-.015.298.023.182.094-.28.188-.542.266-.745.049-.125.241-.614.359-.859.114-.234.211-.369.415-.688.2-.313.415-.448.668-.561.54-.235 1.109.112 1.301.591.086.215.009.713-.028 1.105-.061.647-.254 1.306-.352 1.648-.128.447-.274 1.235-.34 1.601-.072.394-.234 1.382-.359 1.82-.086.301-.371.978-.652 1.384 0 0-1.074 1.25-1.192 1.812-.117.563-.078.567-.101.965-.024.399.121.923.121.923s-.802.104-1.234.034c-.391-.062-.875-.841-1-1.078-.172-.328-.539-.265-.682-.023-.225.383-.709 1.07-1.051 1.113-.668.084-2.054.03-3.139.02 0 0 .185-1.011-.227-1.358-.305-.26-.83-.784-1.144-1.06l-.832-.921c-.284-.36-.629-1.093-1.243-1.985-.348-.504-1.027-1.085-1.284-1.579-.223-.425-.331-.954-.19-1.325.225-.594.675-.897 1.362-.832.519.05.848.206 1.238.537.225.19.573.534.75.748.163.195.203.276.377.509.23.307.302.459.214.121' stroke-linejoin='round'/><path d='m20.5664 21.7344v-3.459'/><path d='m18.5508 21.7461-.016-3.473'/><path d='m16.5547 18.3047.021 3.426'/></g></g></svg>")
			16 16,
		grab;
  --tl-cursor-grabbing: url("data:image/svg+xml,<svg height='32' width='32' viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg' style='color: black;'><defs><filter id='shadow' y='-40%' x='-40%' width='180px' height='180%' color-interpolation-filters='sRGB'><feDropShadow dx='1' dy='1' stdDeviation='1.2' flood-opacity='.5'/></filter></defs><g fill='none' transform='rotate(0 16 16)' filter='url(%23shadow)'><path d='m13.5732 12.0361c.48-.178 1.427-.069 1.677.473.213.462.396 1.241.406 1.075.024-.369-.024-1.167.137-1.584.117-.304.347-.59.686-.691.285-.086.62-.116.916-.055.313.064.642.287.765.499.362.623.368 1.899.385 1.831.064-.272.07-1.229.283-1.584.141-.235.497-.445.687-.479.294-.052.656-.068.964-.008.249.049.586.344.677.487.219.344.342 1.316.379 1.658.016.141.074-.393.293-.736.406-.639 1.844-.763 1.898.639.026.654.02.624.02 1.064 0 .516-.012.828-.04 1.202-.03.399-.116 1.304-.241 1.742-.086.301-.371.978-.653 1.384 0 0-1.074 1.25-1.191 1.812-.117.563-.078.567-.102.965-.023.399.121.923.121.923s-.801.104-1.234.034c-.391-.062-.875-.84-1-1.078-.172-.328-.539-.265-.682-.023-.224.383-.709 1.07-1.05 1.113-.669.084-2.055.03-3.14.02 0 0 .185-1.011-.227-1.358-.305-.26-.83-.784-1.144-1.06l-.832-.921c-.283-.36-1.002-.929-1.243-1.985-.213-.936-.192-1.395.037-1.77.232-.381.67-.589.854-.625.208-.042.692-.039.875.062.223.123.313.159.488.391.23.307.312.456.213.121-.076-.262-.322-.595-.434-.97-.109-.361-.401-.943-.38-1.526.008-.221.103-.771.832-1.042' fill='white'/><g stroke='black' stroke-width='.75'><path d='m13.5732 12.0361c.48-.178 1.427-.069 1.677.473.213.462.396 1.241.406 1.075.024-.369-.024-1.167.137-1.584.117-.304.347-.59.686-.691.285-.086.62-.116.916-.055.313.064.642.287.765.499.362.623.368 1.899.385 1.831.064-.272.07-1.229.283-1.584.141-.235.497-.445.687-.479.294-.052.656-.068.964-.008.249.049.586.344.677.487.219.344.342 1.316.379 1.658.016.141.074-.393.293-.736.406-.639 1.844-.763 1.898.639.026.654.02.624.02 1.064 0 .516-.012.828-.04 1.202-.03.399-.116 1.304-.241 1.742-.086.301-.371.978-.653 1.384 0 0-1.074 1.25-1.191 1.812-.117.563-.078.567-.102.965-.023.399.121.923.121.923s-.801.104-1.234.034c-.391-.062-.875-.84-1-1.078-.172-.328-.539-.265-.682-.023-.224.383-.709 1.07-1.05 1.113-.669.084-2.055.03-3.14.02 0 0 .185-1.011-.227-1.358-.305-.26-.83-.784-1.144-1.06l-.832-.921c-.283-.36-1.002-.929-1.243-1.985-.213-.936-.192-1.395.037-1.77.232-.381.67-.589.854-.625.208-.042.692-.039.875.062.223.123.313.159.488.391.23.307.312.456.213.121-.076-.262-.322-.595-.434-.97-.109-.361-.401-.943-.38-1.526.008-.221.103-.771.832-1.042z' stroke-linejoin='round'/><path d='m20.5664 19.7344v-3.459' stroke-linecap='round'/><path d='m18.5508 19.7461-.016-3.473' stroke-linecap='round'/><path d='m16.5547 16.3047.021 3.426' stroke-linecap='round'/></g></g></svg>")
			16 16,
		grabbing;
  --tl-cursor-text: url("data:image/svg+xml,<svg height='32' width='32' viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg' style='color: black;'><defs><filter id='shadow' y='-40%' x='-40%' width='180px' height='180%' color-interpolation-filters='sRGB'><feDropShadow dx='1' dy='1' stdDeviation='1.2' flood-opacity='.5'/></filter></defs><g fill='none' transform='rotate(0 16 16)' filter='url(%23shadow)'><path fill='white' d='M7.94 0a5.25 5.25 0 0 0-3.47 1.17A5.27 5.27 0 0 0 1 0H0v3h1c1.41 0 1.85.7 2 1v3.94H2v3h1v3c-.13.3-.57 1-2 1H0v3h1a5.27 5.27 0 0 0 3.47-1.17c.98.8 2.21 1.21 3.47 1.17h1v-3h-1c-1.41 0-1.85-.7-2-1v-3H7v-3H6V4c.13-.3.57-1 2-1h1V0H7.94z'/><path fill='black' d='M7.94 2V1a4 4 0 0 0-3.47 1.64A4 4 0 0 0 1 1v1c1.3-.17 2.56.6 3 1.84v5.1H3v1h1v4.16c-.45 1.24-1.7 2-3 1.84v1a4.05 4.05 0 0 0 3.47-1.63 4.05 4.05 0 0 0 3.47 1.63v-1A2.82 2.82 0 0 1 5 14.1V9.93h1v-1H5V3.85A2.81 2.81 0 0 1 7.94 2z'/></g></svg>")
			4 10,
		text;
  --tl-cursor-zoom-in: url("data:image/svg+xml,<svg height='32' width='32' viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg' style='color: black;'><defs><filter id='shadow' y='-40%' x='-40%' width='180px' height='180%' color-interpolation-filters='sRGB'><feDropShadow dx='1' dy='1' stdDeviation='1.2' flood-opacity='.5'/></filter></defs><g fill='none' transform='rotate(0 16 16)' filter='url(%23shadow)'><path d='m20.5 15c0 3.038-2.462 5.5-5.5 5.5s-5.5-2.462-5.5-5.5 2.462-5.5 5.5-5.5 5.5 2.462 5.5 5.5' fill='white'/><path d='m20.5 15c0 3.038-2.462 5.5-5.5 5.5s-5.5-2.462-5.5-5.5 2.462-5.5 5.5-5.5 5.5 2.462 5.5 5.5z' stroke='black'/><g fill='black'><path d='m18 14h-2v-2h-2v2h-2v1.98h2v2.02h2v-2.02h2z'/><path d='m23.5859 25 1.414-1.414-5.449-5.449-1.414 1.414z'/></g></g></svg>")
			16 16,
		zoom-in;
  --tl-cursor-zoom-out: url("data:image/svg+xml,<svg height='32' width='32' viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg' style='color: black;'><defs><filter id='shadow' y='-40%' x='-40%' width='180px' height='180%' color-interpolation-filters='sRGB'><feDropShadow dx='1' dy='1' stdDeviation='1.2' flood-opacity='.5'/></filter></defs><g fill='none' transform='rotate(0 16 16)' filter='url(%23shadow)'><path d='m20.5 15c0 3.038-2.462 5.5-5.5 5.5s-5.5-2.462-5.5-5.5 2.462-5.5 5.5-5.5 5.5 2.462 5.5 5.5' fill='white'/><path d='m20.5 15c0 3.038-2.462 5.5-5.5 5.5s-5.5-2.462-5.5-5.5 2.462-5.5 5.5-5.5 5.5 2.462 5.5 5.5z' stroke='black'/><g fill='black'><path d='m18 16h-5.98v-1.98h5.98z'/><path d='m23.5859 25 1.414-1.414-5.449-5.449-1.414 1.414z'/></g></g></svg>")
			16 16,
		zoom-out;
  --tl-cursor: var(--tl-cursor-default);
  --tl-cursor-resize-edge: ew-resize;
  --tl-cursor-resize-corner: nesw-resize;
  --tl-cursor-ew-resize: ew-resize;
  --tl-cursor-ns-resize: ns-resize;
  --tl-cursor-nesw-resize: nesw-resize;
  --tl-cursor-nwse-resize: nwse-resize;
  --tl-cursor-rotate: pointer;
  --tl-cursor-nwse-rotate: pointer;
  --tl-cursor-nesw-rotate: pointer;
  --tl-cursor-senw-rotate: pointer;
  --tl-cursor-swne-rotate: pointer;
  --tl-scale: calc(1 / var(--tl-zoom));
  --tl-font-draw: "tldraw_draw", sans-serif;
  --tl-font-sans: "tldraw_sans", sans-serif;
  --tl-font-serif: "tldraw_serif", serif;
  --tl-font-mono: "tldraw_mono", monospace;
  --tl-text-outline-a: calc(min(.5, 1 / var(--tl-zoom)) * 2px);
  --tl-text-outline-b: calc(min(.5, 1 / var(--tl-zoom)) * -2px);
  --tl-text-outline-reference: 0 var(--tl-text-outline-b) 0 var(--tl-color-background),
		0 var(--tl-text-outline-a) 0 var(--tl-color-background),
		var(--tl-text-outline-b) var(--tl-text-outline-b) 0 var(--tl-color-background),
		var(--tl-text-outline-a) var(--tl-text-outline-b) 0 var(--tl-color-background),
		var(--tl-text-outline-a) var(--tl-text-outline-a) 0 var(--tl-color-background),
		var(--tl-text-outline-b) var(--tl-text-outline-a) 0 var(--tl-color-background);
  --tl-text-outline: var(--tl-text-outline-reference);
  width: 100%;
  height: 100%;
  color: var(--tl-color-text);
  font-size: 12px;
  position: relative;
  inset: 0;
  overflow: clip;
}

.tl-theme__light {
  --tl-color-selection-fill: #1f8fff3d;
  --tl-color-selection-stroke: #3182ed;
  --tl-color-background: #f9fafb;
  --tl-color-grid: #6e6e6e;
  --tl-color-low: #edf0f2;
  --tl-color-low-border: #e7ebee;
  --tl-color-muted-none: #0000;
  --tl-color-muted-0: #00000005;
  --tl-color-muted-1: #0000001a;
  --tl-color-muted-2: #0000000b;
  --tl-color-hint: #0000000e;
  --tl-color-overlay: #0003;
  --tl-color-divider: #e8e8e8;
  --tl-color-panel: #fcfcfc;
  --tl-color-panel-contrast: #fff;
  --tl-color-panel-overlay: #ffffffd1;
  --tl-color-panel-transparent: #fcfcfc00;
  --tl-color-selected: #3182ed;
  --tl-color-selected-contrast: #fff;
  --tl-color-focus: #2d67d2;
  --tl-color-tooltip: #090b0c;
  --tl-color-text: #000;
  --tl-color-text-0: #1c1c1c;
  --tl-color-text-1: #2e2e2e;
  --tl-color-text-3: #6e7477;
  --tl-color-text-disabled: #888d91;
  --tl-color-text-shadow: #fff;
  --tl-color-text-highlight: #fd0;
  --tl-color-text-highlight-p3: #fad100;
  --tl-color-primary: #3182ed;
  --tl-color-success: #2f7f33;
  --tl-color-info: #0287cf;
  --tl-color-warning: #ed6c02;
  --tl-color-danger: #d00b0b;
  --tl-shadow-1: 0px 1px 2px #00000040, 0px 1px 3px #00000017;
  --tl-shadow-2: 0px 0px 2px #00000029, 0px 2px 3px #0000003d,
		0px 2px 6px #0000001a, inset 0px 0px 0px 1px var(--tl-color-panel-contrast);
  --tl-shadow-3: 0px 1px 2px #00000047, 0px 2px 6px #00000024,
		inset 0px 0px 0px 1px var(--tl-color-panel-contrast);
  --tl-shadow-4: 0px 0px 3px #00000030, 0px 5px 4px #00000029,
		0px 2px 16px #0000000f, inset 0px 0px 0px 1px var(--tl-color-panel-contrast);
}

@supports (color: color(display-p3 0 0 0)) {
  .tl-theme__light {
    --tl-color-text-highlight-p3: color(display-p3 .972 .8205 .05);
  }
}

.tl-theme__dark {
  --tl-color-selection-fill: #2495ff33;
  --tl-color-selection-stroke: #3182ed;
  --tl-color-background: #101011;
  --tl-color-grid: #666;
  --tl-color-low: #1a1a1c;
  --tl-color-low-border: #171a1c;
  --tl-color-muted-none: #fff0;
  --tl-color-muted-0: #ffffff05;
  --tl-color-muted-1: #ffffff1a;
  --tl-color-muted-2: #ffffff0d;
  --tl-color-hint: #ffffff12;
  --tl-color-overlay: #00000080;
  --tl-color-divider: #33333d;
  --tl-color-panel: #202025;
  --tl-color-panel-contrast: #353442;
  --tl-color-panel-overlay: #373d43d1;
  --tl-color-panel-transparent: #20202500;
  --tl-color-selected: #4387f4;
  --tl-color-selected-contrast: #fff;
  --tl-color-focus: #a5c3f3;
  --tl-color-tooltip: #fff;
  --tl-color-text: #f9fafb;
  --tl-color-text-0: #f1eeee;
  --tl-color-text-1: #d9d9d9;
  --tl-color-text-3: #bdc0c2;
  --tl-color-text-disabled: #7a8185;
  --tl-color-text-shadow: #282e34;
  --tl-color-text-highlight: #d1b500;
  --tl-color-text-highlight-p3: #d49d00;
  --tl-color-primary: #3182ed;
  --tl-color-success: #68bb6c;
  --tl-color-info: #28b5f6;
  --tl-color-warning: #ffa724;
  --tl-color-danger: #ef6161;
  --tl-shadow-1: 0px 1px 2px #00000029, 0px 1px 3px #00000038,
		inset 0px 0px 0px 1px var(--tl-color-panel-contrast);
  --tl-shadow-2: 0px 1px 3px #000a, 0px 2px 6px #00000054,
		inset 0px 0px 0px 1px var(--tl-color-panel-contrast);
  --tl-shadow-3: 0px 1px 3px #00000080, 0px 2px 12px #00000080,
		inset 0px 0px 0px 1px var(--tl-color-panel-contrast);
}

@supports (color: color(display-p3 0 0 0)) {
  .tl-theme__dark {
    --tl-color-text-highlight-p3: color(display-p3 .8078 .6225 .0312);
  }
}

.tl-counter-scaled {
  transform: scale(var(--tl-scale));
  transform-origin: 0 0;
  width: calc(100% * var(--tl-zoom));
  height: calc(100% * var(--tl-zoom));
}

.tl-container, .tl-container * {
  -webkit-touch-callout: none;
  -webkit-tap-highlight-color: transparent;
  scrollbar-highlight-color: transparent;
  -webkit-user-select: none;
  user-select: none;
  box-sizing: border-box;
  outline: none;
}

.tl-container a {
  -webkit-touch-callout: initial;
}

.tl-container__focused {
  outline: 1px solid var(--tl-color-low);
}

input, [contenteditable], [contenteditable] * {
  -webkit-user-select: text;
  user-select: text;
}

.tl-canvas {
  width: 100%;
  height: 100%;
  color: var(--tl-color-text);
  cursor: var(--tl-cursor);
  content-visibility: auto;
  touch-action: none;
  contain: strict;
  position: absolute;
  inset: 0;
  overflow: clip;
}

.tl-canvas__in-front {
  pointer-events: none;
  z-index: var(--tl-layer-canvas-in-front);
  position: absolute;
  inset: 0;
}

.tl-shapes {
  z-index: var(--tl-layer-canvas-shapes);
  position: relative;
}

.tl-svg-context {
  pointer-events: none;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.tl-background__wrapper {
  z-index: var(--tl-layer-canvas-background);
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
}

.tl-background {
  background-color: var(--tl-color-background);
  width: 100%;
  height: 100%;
}

.tl-grid {
  touch-action: none;
  pointer-events: none;
  width: 100%;
  height: 100%;
  z-index: var(--tl-layer-canvas-grid);
  contain: strict;
  position: absolute;
  inset: 0;
}

.tl-grid-dot {
  fill: var(--tl-color-grid);
}

.tl-html-layer {
  contain: layout style size;
  width: 1px;
  height: 1px;
  position: absolute;
  top: 0;
  left: 0;
}

.tl-selection__bg {
  transform-origin: 0 0;
  pointer-events: all;
  background-color: #0000;
  position: absolute;
  top: 0;
  left: 0;
}

.tl-transparent {
  fill: #0000;
  stroke: #0000;
}

.tl-hidden {
  opacity: 0;
  pointer-events: none;
}

.tl-nametag {
  white-space: nowrap;
  text-overflow: ellipsis;
  border-radius: var(--tl-radius-2);
  width: fit-content;
  max-width: 120px;
  height: fit-content;
  color: var(--tl-color-selected-contrast);
  padding: 3px 6px;
  font-size: 12px;
  position: absolute;
  top: 16px;
  left: 13px;
  overflow: hidden;
}

.tl-nametag-title {
  white-space: nowrap;
  text-overflow: ellipsis;
  width: fit-content;
  max-width: 120px;
  height: fit-content;
  text-shadow: var(--tl-text-outline);
  color: var(--tl-color-selected-contrast);
  padding: 0 6px;
  font-size: 12px;
  position: absolute;
  top: -2px;
  left: 13px;
  overflow: hidden;
}

.tl-nametag-chat {
  width: fit-content;
  height: fit-content;
  color: var(--tl-color-selected-contrast);
  white-space: nowrap;
  opacity: 1;
  border-radius: var(--tl-radius-2);
  padding: 3px 6px;
  font-size: 12px;
  position: absolute;
  top: 16px;
  left: 13px;
}

.tl-cursor-chat {
  color: var(--tl-color-selected-contrast);
  white-space: nowrap;
  pointer-events: none;
  z-index: var(--tl-layer-cursor);
  opacity: 1;
  -webkit-user-select: text;
  user-select: text;
  border-radius: var(--tl-radius-2);
  border: none;
  margin-top: 16px;
  margin-left: 13px;
  padding: 3px 6px;
  font-size: 12px;
  position: absolute;
}

.tl-cursor-chat .tl-cursor-chat__bubble {
  padding-right: 12px;
}

.tl-cursor-chat::selection {
  background: var(--tl-color-selected);
  color: var(--tl-color-selected-contrast);
  text-shadow: none;
}

.tl-cursor-chat::placeholder {
  color: var(--tl-color-selected-contrast);
  opacity: .7;
}

.tl-text-shape-label {
  font-variant: normal;
  pointer-events: all;
  white-space: pre-wrap;
  overflow-wrap: break-word;
  border: none;
  width: fit-content;
  min-width: 1px;
  height: fit-content;
  margin: 0;
  padding: 0;
  font-style: normal;
  font-weight: normal;
  position: relative;
}

.tl-plain-text-wrapper[data-isediting="true"] .tl-text-content {
  opacity: 0;
}

.tl-rich-text-wrapper[data-isediting="true"] .tl-text-content {
  display: none;
}

.tl-text {
  appearance: auto;
  caret-color: var(--tl-color-text);
  color: inherit;
  font-feature-settings: normal;
  font-kerning: auto;
  font-optical-sizing: auto;
  font-family: inherit;
  font-size: inherit;
  font-stretch: 100%;
  font-style: inherit;
  font-variant: inherit;
  font-variation-settings: normal;
  font-weight: inherit;
  letter-spacing: inherit;
  line-height: inherit;
  overflow-wrap: break-word;
  text-align: inherit;
  text-indent: 0;
  text-rendering: auto;
  text-shadow: inherit;
  text-transform: none;
  white-space: pre-wrap;
  line-break: normal;
  word-spacing: 0;
  word-wrap: break-word;
  background: none;
  border: 0;
  outline: none;
  margin: 0;
  padding: 0;
  display: inline-block;
  column-count: initial !important;
  writing-mode: horizontal-tb !important;
}

.tl-text-measure {
  z-index: var(--tl-layer-canvas-hidden);
  opacity: 0;
  visibility: hidden;
  box-sizing: border-box;
  pointer-events: none;
  white-space: pre-wrap;
  word-wrap: break-word;
  overflow-wrap: break-word;
  resize: none;
  -webkit-user-select: none;
  user-select: none;
  contain: layout style paint;
  unicode-bidi: plaintext;
  border: none;
  width: max-content;
  position: absolute;
  top: 0;
  left: 0;
}

.tl-text-input, .tl-text-content {
  outline: none;
  width: 100%;
  min-width: 1px;
  height: 100%;
  min-height: 1px;
  position: absolute;
  inset: 0;
}

.tl-text-content__wrapper {
  pointer-events: none;
  justify-content: center;
  align-items: center;
  width: fit-content;
  height: fit-content;
  min-height: auto;
  display: flex;
  position: relative;
}

.tl-text-content {
  pointer-events: none;
  overflow: visible;
}

.tl-text-input {
  resize: none;
  -webkit-user-select: text;
  user-select: text;
  cursor: var(--tl-cursor-text);
}

.tl-text-input:not(.tl-rich-text) {
  overflow: hidden;
}

.tl-text-input::selection {
  background: var(--tl-color-selected);
  color: var(--tl-color-selected-contrast);
  text-shadow: none;
}

.tl-text-label {
  color: var(--tl-color-text);
  line-height: inherit;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
  position: absolute;
  inset: 0;
}

.tl-text-label[data-hastext="false"][data-isediting="false"] > .tl-text-label__inner {
  width: 40px;
  height: 40px;
}

.tl-text-label[data-hastext="true"][data-isediting="false"] .tl-text-content {
  pointer-events: all;
}

.tl-text-label__inner > .tl-text-input.tl-rich-text {
  display: none;
  position: static;
}

.tl-text-wrapper[data-isediting="false"] .tl-text-input {
  opacity: 0;
  cursor: var(--tl-cursor-default);
}

.tl-rich-text[data-is-ready-for-editing="true"], .tl-text-wrapper[data-is-ready-for-editing="true"] .tl-text-input {
  cursor: var(--tl-cursor-text);
}

.tl-text-label[data-textwrap="true"] > .tl-text-label__inner {
  max-width: 100%;
}

.tl-text-label[data-isediting="true"] {
  background-color: #0000;
  min-height: auto;
}

.tl-text-wrapper .tl-text-content {
  pointer-events: all;
  z-index: var(--tl-layer-text-content);
}

.tl-text-label__inner > .tl-text-content {
  padding: inherit;
  border-radius: var(--tl-radius-1);
  width: fit-content;
  max-width: 100%;
  height: fit-content;
  position: relative;
  top: 0;
  left: 0;
}

.tl-text-label__inner > .tl-text-input {
  width: 100%;
  height: 100%;
  padding: inherit;
  position: absolute;
  inset: 0;
}

.tl-text-wrapper[data-isselected="true"] .tl-text-input {
  z-index: var(--tl-layer-text-editor);
  pointer-events: all;
}

.tl-canvas:is([data-iseditinganything="true"], [data-isselectinganything="true"]) .tl-shape:not([data-shape-type="arrow"], [data-shape-type="draw"], [data-shape-type="line"], [data-shape-type="highlight"], [data-shape-is-filled="false"]) {
  pointer-events: all;
}

.tl-rich-text .ProseMirror {
  word-wrap: break-word;
  overflow-wrap: break-word;
  white-space: pre-wrap;
  -webkit-font-variant-ligatures: inherit;
  font-variant-ligatures: inherit;
  font-feature-settings: inherit;
}

.tl-rich-text {
  tab-size: var(--tl-tab-size, 2);
}

.tl-rich-text p {
  min-height: 1lh;
  margin: 0;
}

.tl-rich-text ul, .tl-rich-text ol {
  text-align: left;
  list-style: revert;
  margin: 0;
  padding-left: 1.625ch;
}

.tl-rich-text ol:has( > li:nth-child(10)) {
  padding-left: 2.625ch;
}

.tl-rich-text ol:has( > li:nth-child(100)) {
  padding-left: 3.625ch;
}

.tl-rich-text h1, .tl-rich-text h2, .tl-rich-text h3, .tl-rich-text h4, .tl-rich-text h5, .tl-rich-text h6 {
  margin-top: 5px;
  margin-bottom: 10px;
}

.tl-rich-text a {
  color: var(--tl-color-primary);
  text-decoration: underline;
}

.tl-rich-text[data-is-select-tool-active="false"] a {
  cursor: inherit;
}

.tl-rich-text code {
  font-family: var(--tl-font-mono);
}

.tl-rich-text mark {
  color: currentColor;
  background-color: #fddd00;
  border-radius: 2px;
}

.tl-theme__light .tl-rich-text mark {
  text-shadow: none;
}

.tl-theme__dark .tl-rich-text mark {
  background-color: var(--tl-color-text-highlight);
  color: currentColor;
  text-shadow: none;
}

@supports (color: color(display-p3 1 1 1)) {
  @media (color-gamut: p3) {
    .tl-container:not(.tl-theme__force-sRGB) .tl-rich-text mark {
      background-color: var(--tl-color-text-highlight-p3);
    }
  }
}

.tl-text-wrapper[data-isediting="true"] .tl-rich-text {
  display: block;
}

.tl-text__outline {
  text-shadow: var(--tl-text-outline);
}

.tl-text__no-outline {
  text-shadow: none;
}

.tl-loading {
  background-color: var(--tl-color-background);
  color: var(--tl-color-text-1);
  justify-content: center;
  align-items: center;
  gap: var(--tl-space-2);
  opacity: 0;
  width: 100%;
  height: 100%;
  z-index: var(--tl-layer-canvas-blocker);
  flex-direction: column;
  font-size: 14px;
  font-weight: 500;
  animation: .2s ease-in-out .2s forwards tl-fade-in;
  display: flex;
  position: absolute;
  inset: 0;
}

@keyframes tl-fade-in {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

.tl-spinner {
  animation: 1s linear infinite tl-spin;
}

@keyframes tl-spin {
  0% {
    transform: rotate(0);
  }

  100% {
    transform: rotate(360deg);
  }
}

.tl-hyperlink-button {
  width: 44px;
  height: 44px;
  color: var(--tl-color-text-1);
  cursor: var(--tl-cursor-pointer);
  pointer-events: all;
  z-index: 1;
  background: none;
  border: none;
  outline: none;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 13px;
  font-size: 12px;
  font-weight: 400;
  display: flex;
  position: absolute;
  top: 0;
  right: 0;
}

.tl-hyperlink-button:after {
  content: "";
  z-index: -1;
  border-radius: var(--tl-radius-1);
  background-color: var(--tl-color-background);
  pointer-events: none;
  width: calc(100% - 12px);
  height: calc(100% - 12px);
  display: block;
  position: absolute;
  bottom: 6px;
  right: 6px;
}

.tl-hyperlink-button:focus-visible {
  color: var(--tl-color-selected);
}

.tl-hyperlink__icon {
  pointer-events: none;
  background-color: currentColor;
  width: 15px;
  height: 15px;
}

.tl-hyperlink-button__hidden {
  display: none;
}

.tl-shape-indicator {
  transform-origin: 0 0;
  fill: none;
  stroke-width: calc(1.5px * var(--tl-scale));
  contain: size layout;
}

.tl-canvas-overlays {
  pointer-events: none;
  z-index: var(--tl-layer-canvas-overlays);
  position: absolute;
  inset: 0;
}

.tl-shape {
  pointer-events: none;
  transform-origin: 0 0;
  contain: size layout;
  position: absolute;
  overflow: visible;
}

.tl-svg-container {
  pointer-events: none;
  stroke-linecap: round;
  stroke-linejoin: round;
  transform-origin: 0 0;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
  overflow: visible;
}

.tl-html-container {
  pointer-events: none;
  stroke-linecap: round;
  stroke-linejoin: round;
  transform-origin: 0 0;
  width: 100%;
  height: 100%;
  color: var(--tl-color-text-1);
  position: absolute;
  inset: 0;
}

.tl-content-slot {
  pointer-events: none;
  transform-origin: 0 0;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
}

.tl-group {
  stroke: var(--tl-color-text);
  stroke-width: calc(1px * var(--tl-scale));
  opacity: .5;
}

.tl-shape[data-shape-type="arrow"] .tl-text-label {
  text-align: center;
  width: 2px;
  height: 2px;
  color: var(--tl-color-text);
  justify-content: center;
  align-items: center;
  padding: 0;
  display: flex;
  position: absolute;
  top: -1px;
  left: -1px;
}

.tl-shape[data-shape-type="arrow"] .tl-text-label__inner {
  border-radius: var(--tl-radius-1);
  box-sizing: content-box;
  width: max-content;
  height: max-content;
}

.tl-shape[data-shape-type="arrow"] .tl-text {
  height: max-content;
}

.tl-bookmark__container {
  border: 1px solid var(--tl-color-panel-contrast);
  background-color: var(--tl-color-panel);
  border-radius: var(--tl-radius-2);
  flex-direction: column;
  width: 100%;
  height: 100%;
  display: flex;
  position: relative;
  overflow: hidden;
}

.tl-bookmark__container--safariExport {
  border: 1px solid var(--tl-color-divider);
}

.tl-bookmark__image_container {
  border-top-left-radius: var(--tl-radius-1);
  border-top-right-radius: var(--tl-radius-1);
  width: 100%;
  height: 100%;
  box-shadow: inset 0px 0px 0px 1px var(--tl-color-divider);
  flex: 100%;
  justify-content: flex-end;
  align-items: flex-start;
  display: flex;
  overflow: hidden;
}

.tl-bookmark__image_container > .tl-hyperlink-button:after {
  background-color: var(--tl-color-panel);
}

.tl-bookmark__placeholder {
  background-color: var(--tl-color-muted-2);
  border-bottom: 1px solid var(--tl-color-muted-2);
  width: 100%;
  height: 100%;
}

.tl-bookmark__image {
  object-fit: cover;
  object-position: center;
  border-bottom: 1px solid var(--tl-color-muted-2);
  width: 100%;
  height: 100%;
}

.tl-bookmark__copy_container {
  background-color: var(--tl-color-muted-0);
  padding: var(--tl-space-4);
  pointer-events: all;
  flex-direction: column;
  flex: 1;
  justify-content: space-between;
  display: flex;
}

.tl-bookmark__copy_container:has(.tl-bookmark__link:only-child) {
  justify-content: center;
}

.tl-bookmark__heading, .tl-bookmark__description, .tl-bookmark__link {
  width: 100%;
  margin: 0;
  font-family: inherit;
}

.tl-bookmark__heading {
  padding-bottom: var(--tl-space-2);
  -webkit-line-clamp: 2;
  line-clamp: 2;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  max-height: 51.2px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.6;
  display: -webkit-box;
  overflow: hidden;
}

.tl-bookmark__description {
  -webkit-line-clamp: 3;
  line-clamp: 3;
  text-overflow: ellipsis;
  max-height: 54px;
  color: var(--tl-color-text-1);
  margin: var(--tl-space-2) 0px;
  -webkit-box-orient: vertical;
  font-size: 12px;
  line-height: 1.5;
  display: -webkit-box;
  overflow: hidden;
}

.tl-bookmark__heading + .tl-bookmark__link, .tl-bookmark__description + .tl-bookmark__link {
  margin-top: var(--tl-space-3);
}

.tl-bookmark__link {
  pointer-events: all;
  color: var(--tl-color-text-1);
  cursor: var(--tl-cursor-pointer);
  align-items: center;
  width: fit-content;
  max-width: 100%;
  font-size: 12px;
  text-decoration: none;
  display: flex;
}

.tl-bookmark__link > span {
  flex-shrink: 0px;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}

.tl-bookmark__link > .tl-hyperlink__icon {
  flex-shrink: 0;
  margin-right: 8px;
}

.tl-bookmark__link > .tl-bookmark__favicon {
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  margin-right: 8px;
}

.tl-image, .tl-video {
  object-fit: cover;
  background-size: cover;
  width: 100%;
  height: 100%;
}

.tl-video-container, .tl-image-container, .tl-embed-container {
  pointer-events: all;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
}

.tl-image-container {
  position: relative;
}

.tl-image {
  position: absolute;
  inset: 0;
}

.tl-video.tl-video-is-fullscreen {
  object-fit: contain;
  background-size: contain;
}

.tl-note__container {
  pointer-events: all;
  opacity: 1;
  width: 100%;
  height: 100%;
  z-index: var(--tl-layer-text-container);
  border-radius: 1px;
  position: relative;
}

.tl-note__container > .tl-text-label {
  color: currentColor;
}

.tl-note__attribution {
  bottom: calc(4px * var(--note-attribution-scale, 1));
  right: calc(8px * var(--note-attribution-scale, 1));
  font-family: var(--tl-font-sans);
  pointer-events: auto;
  white-space: nowrap;
  text-overflow: ellipsis;
  z-index: 1;
  max-width: 60%;
  position: absolute;
  overflow: hidden;
}

.tl-frame__body {
  stroke-width: calc(1px * var(--tl-scale));
}

.tl-frame__creating {
  stroke: var(--tl-color-selected);
  fill: none;
}

.tl-frame-heading {
  --tl-frame-padding-x: 6px;
  --tl-frame-height: 24px;
  --tl-frame-minimum-width: 32px;
  --tl-frame-offset-width: 16px;
  transform-origin: 0 100%;
  max-width: 100%;
  min-width: var(--tl-frame-minimum-width);
  pointer-events: all;
  align-items: center;
  height: auto;
  padding-bottom: 4px;
  font-size: 12px;
  display: flex;
  position: absolute;
  overflow: hidden;
}

.tl-frame-heading-hit-area {
  pointer-events: all;
  transform-origin: 0 100%;
  height: var(--tl-frame-height);
  border-radius: var(--tl-radius-1);
  align-items: center;
  width: 100%;
  display: flex;
}

.tl-frame-label {
  pointer-events: all;
  text-overflow: ellipsis;
  padding: 0px var(--tl-frame-padding-x);
  border-radius: var(--tl-radius-1);
  font-size: inherit;
  white-space: pre;
  position: relative;
  overflow: hidden;
}

.tl-frame-label__editing {
  color: #0000;
  white-space: pre;
  width: auto;
  min-width: var(--tl-frame-minimum-width);
  background-color: var(--tl-color-panel);
  border-color: var(--tl-color-selected);
  height: 100%;
  box-shadow: inset 0px 0px 0px 1.5px var(--tl-color-selected);
  overflow: visible;
}

.tl-frame-name-input {
  padding: 0px var(--tl-frame-padding-x);
  width: 100%;
  height: 100%;
  font-size: inherit;
  font-family: inherit;
  font-weight: inherit;
  width: 100%;
  color: var(--tl-color-text-1);
  border-radius: var(--tl-radius-1);
  -webkit-user-select: text;
  user-select: text;
  white-space: pre;
  cursor: var(--tl-cursor-text);
  background: none;
  border: none;
  outline: none;
  position: absolute;
  inset: 0;
}

.tl-embed {
  border-radius: var(--tl-radius-2);
  border: none;
}

.tl-shape-error-boundary {
  background-color: var(--tl-color-muted-1);
  border-width: calc(1px * var(--tl-scale));
  border-color: var(--tl-color-muted-1);
  border-radius: calc(var(--tl-radius-1) * var(--tl-scale));
  text-align: left;
  pointer-events: all;
  width: 100%;
  height: 100%;
  padding: var(--tl-space-2);
  border-style: solid;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  display: flex;
  position: relative;
  overflow: hidden;
}

.tl-shape-error-boundary:before {
  transform: scale(var(--tl-scale));
  content: "Error";
  color: var(--tl-color-text-0);
  font-family: inherit;
  font-size: 12px;
}

.tl-error-boundary {
  width: 100%;
  height: 100%;
  padding: var(--tl-space-4);
  background-color: var(--tl-color-background);
  color: var(--tl-color-text-1);
  justify-content: center;
  align-items: center;
  display: flex;
  position: absolute;
}

.tl-error-boundary__overlay {
  width: 100%;
  height: 100%;
  z-index: var(--tl-layer-error-overlay);
  background-color: var(--tl-color-overlay);
  position: absolute;
  inset: 0;
}

.tl-error-boundary__content * {
  -webkit-user-select: text;
  user-select: text;
  pointer-events: all;
}

.tl-error-boundary__canvas {
  pointer-events: none;
  width: 100%;
  height: 100%;
  z-index: var(--tl-layer-error-canvas);
  position: absolute;
  inset: 0;
}

.tl-error-boundary__canvas:after {
  content: " ";
  width: 100%;
  height: 100%;
  z-index: var(--tl-layer-error-canvas-after);
  pointer-events: all;
  display: block;
  position: absolute;
  inset: 0;
}

.tl-error-boundary__content {
  background-color: var(--tl-color-panel);
  width: 400px;
  max-width: 100%;
  height: fit-content;
  max-height: 100%;
  box-shadow: var(--tl-shadow-2);
  z-index: var(--tl-layer-error-content);
  border-radius: 16px;
  flex-direction: column;
  gap: 12px;
  padding: 16px;
  font-size: 14px;
  font-weight: 400;
  display: flex;
  overflow: auto;
}

.tl-error-boundary__content__expanded {
  width: 600px;
}

.tl-error-boundary__content h2 {
  margin: 0;
  font-size: 16px;
  font-weight: 500;
}

.tl-error-boundary__content h4 {
  border: 1px solid var(--tl-color-low-border);
  padding: var(--tl-space-5);
  border-radius: var(--tl-radius-2);
  margin: -6px 0 0;
  font-weight: normal;
}

.tl-error-boundary__content p {
  margin: 0;
  line-height: 1.5;
}

.tl-error-boundary__content pre {
  background-color: var(--tl-color-muted-2);
  padding: var(--tl-space-5);
  border-radius: var(--tl-radius-2);
  max-height: 320px;
  margin-top: 0;
  font-size: 12px;
  overflow: auto;
}

.tl-error-boundary__content button {
  padding: var(--tl-space-4);
  border-radius: var(--tl-radius-3);
  cursor: var(--tl-cursor-pointer);
  color: inherit;
  background: none;
  border: none;
  font-family: inherit;
  font-size: 14px;
  font-weight: 500;
}

.tl-error-boundary__content a {
  color: var(--tl-color-selected);
  font-weight: 500;
  text-decoration: none;
}

.tl-error-boundary__content__error {
  margin: -6px 0 0;
  position: relative;
}

.tl-error-boundary__content__error button {
  top: var(--tl-space-2);
  right: var(--tl-space-2);
  padding: var(--tl-space-2) var(--tl-space-3);
  background-color: var(--tl-color-panel);
  border-radius: var(--tl-radius-1);
  font-size: 12px;
  position: absolute;
}

.tl-error-boundary__content__actions {
  justify-content: space-between;
  gap: var(--tl-space-4);
  margin: 0 0 0 -4px;
  display: flex;
}

.tl-error-boundary__content__actions__group {
  gap: var(--tl-space-4);
  display: flex;
}

.tl-error-boundary__content .tl-error-boundary__reset {
  color: var(--tl-color-danger);
}

.tl-error-boundary__content .tl-error-boundary__refresh {
  background-color: var(--tl-color-primary);
  color: var(--tl-color-selected-contrast);
}

.tl-container__focused:not(.tl-container__no-focus-ring) .tlui-button.tl-error-boundary__refresh:focus-visible {
  outline-offset: 0;
  border-radius: 8px;
}

.tl-hit-test-blocker {
  z-index: var(--tl-layer-canvas-blocker);
  pointer-events: all;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
}

.tl-hit-test-blocker__hidden {
  display: none;
}

@media (hover: hover) {
  .tl-handle__create:hover {
    opacity: 1;
  }

  .tl-handle__bg:hover {
    cursor: var(--tl-cursor-grab);
    fill: var(--tl-color-selection-fill);
  }

  .tl-bookmark__link:hover, .tl-hyperlink-button:hover {
    color: var(--tl-color-selected);
  }

  .tl-error-boundary__content button:hover {
    background-color: var(--tl-color-low);
  }

  .tl-error-boundary__content a:hover {
    color: var(--tl-color-text-1);
  }

  .tl-error-boundary__content .tl-error-boundary__refresh:hover {
    background-color: var(--tl-color-primary);
    opacity: .9;
  }

  .tl-canvas[data-iseditinganything="true"] .tl-text-wrapper:hover .tl-text-input {
    z-index: var(--tl-layer-text-editor);
    pointer-events: all;
  }
}

.tl-container {
  --tl-layer-above: 1;
  --tl-layer-focused-input: 10;
  --tl-layer-menu-click-capture: 250;
  --tl-layer-panels: 300;
  --tl-layer-menus: 400;
  --tl-layer-toasts: 650;
  --tl-layer-cursor: 700;
  --tl-layer-header-footer: 999;
}

.tlui-button {
  color: var(--tl-color-text-1);
  cursor: pointer;
  pointer-events: all;
  min-width: 40px;
  height: 40px;
  font-weight: inherit;
  font-family: inherit;
  line-height: inherit;
  text-rendering: optimizelegibility;
  z-index: 0;
  background-color: #0000;
  border: #0000;
  justify-content: center;
  align-items: center;
  gap: 0;
  padding: 0 12px;
  font-size: 12px;
  display: flex;
  position: relative;
}

.tlui-button:disabled, .tlui-button[data-disabled] {
  color: var(--tl-color-text-disabled);
  text-shadow: none;
  cursor: default;
}

.tlui-button:disabled .tlui-kbd, .tlui-button[data-disabled] .tlui-kbd {
  color: var(--tl-color-text-disabled);
}

.tlui-button > * {
  z-index: var(--tl-layer-above);
  position: relative;
}

.tlui-button__label {
  text-align: start;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex-grow: 2;
  min-width: 0;
  font-size: 12px;
  overflow: hidden;
}

.tl-container__focused:not(.tl-container__no-focus-ring) .tlui-button:focus-visible {
  outline: 2px solid var(--tl-color-focus);
  outline-offset: -5px;
  border-radius: 10px;
}

.tl-container__focused:not(.tl-container__no-focus-ring) .tlui-button__tool:focus-visible {
  border-radius: 12px;
}

.tlui-slider__container:has(.tlui-slider__thumb:focus-visible) {
  outline: 2px solid var(--tl-color-focus);
  outline-offset: -5px;
  border-radius: 10px;
}

.tlui-button:after {
  content: "";
  border-radius: var(--tl-radius-2);
  background: var(--tl-color-muted-2);
  opacity: 0;
  display: block;
  position: absolute;
  inset: 4px;
}

.tlui-button__menu[data-highlighted]:after {
  opacity: 1;
}

.tlui-button[data-isactive="true"]:after, .tlui-button[data-isactive="true"]:not(:disabled, [data-disabled], :focus-visible):active:after {
  background: var(--tl-color-hint);
  opacity: 1;
}

.tlui-button[aria-expanded="true"][data-direction="left"] {
  background: linear-gradient(270deg, #90909000 0%, var(--tl-color-muted-2) 100%);
  opacity: 1;
}

@media (hover: hover) {
  .tlui-button[aria-expanded="true"][data-direction="left"]:not(:hover):after {
    background: linear-gradient(270deg, #90909000 0%, var(--tl-color-muted-2) 100%);
    opacity: 1;
  }

  .tlui-button:not(:disabled, [data-disabled]):hover {
    z-index: 1;
  }

  .tlui-button:not(:disabled, [data-disabled]):hover:after {
    opacity: 1;
  }
}

.tlui-button__icon + .tlui-button__label {
  margin-inline-start: var(--tl-space-2);
}

.tlui-button__low {
  border-radius: var(--tl-radius-3);
  background-color: var(--tl-color-low);
}

.tlui-button__low:after {
  background-color: var(--tl-color-muted-2);
  opacity: 0;
}

@media (hover: hover) {
  .tlui-button__low:hover:after {
    opacity: 1;
  }
}

.tlui-button__primary {
  color: var(--tl-color-primary);
}

.tlui-button__danger {
  color: var(--tl-color-danger);
  text-shadow: none;
}

@media (hover: hover) {
  .tlui-button__primary:not(:disabled, [data-disabled], :focus-visible):hover {
    color: var(--tl-color-primary);
  }

  .tlui-button__danger:not(:disabled, [data-disabled], :focus-visible):hover {
    color: var(--tl-color-danger);
    text-shadow: none;
  }
}

.tlui-button__menu {
  gap: 8px;
  width: 100%;
  height: 40px;
  min-height: 40px;
  margin-top: -4px;
}

.tlui-button__menu:after {
  border-radius: var(--tl-radius-2);
  inset: 4px;
}

.tlui-button__menu > .tlui-icon + .tlui-button__label {
  margin-inline-start: 0;
}

.tlui-button__menu:first-child {
  margin-top: 0;
}

.tlui-button__menu:last-child {
  margin-bottom: 0;
}

.tlui-button__checkbox {
  padding-left: 8px;
}

.tlui-button__checkbox__indicator {
  width: 15px;
  height: 15px;
}

.tlui-main-toolbar__lock-button {
  pointer-events: all;
  border-radius: var(--tl-radius-2);
  width: 40px;
  height: 40px;
  position: absolute;
}

.tlui-main-toolbar--horizontal .tlui-main-toolbar__lock-button {
  min-width: 0;
  top: 4px;
  right: 0;
}

.tlui-main-toolbar--vertical .tlui-main-toolbar__lock-button {
  min-height: 0;
  bottom: 0;
}

.tlui-main-toolbar__lock-button:after {
  top: 4px;
  left: 8px;
  inset: 4px;
}

.tlui-button__tool {
  width: 48px;
  height: 48px;
  position: relative;
}

.tlui-button__tool:after {
  border-radius: 8px;
  inset: 4px;
}

.tlui-button__tool[aria-pressed="true"], .tlui-button__tool[aria-pressed="true"]:not(:disabled, [data-disabled], :focus-visible):active {
  color: var(--tl-color-selected-contrast);
}

.tlui-button__tool[aria-pressed="true"]:not(:disabled, [data-disabled]):after {
  background: var(--tl-color-selected);
  opacity: 1;
}

.tlui-layout__mobile .tlui-main-toolbar--horizontal .tlui-button__tool {
  width: 43px;
  height: 48px;
}

.tlui-layout__mobile .tlui-main-toolbar--horizontal .tlui-button__tool > .tlui-icon {
  width: 16px;
  height: 16px;
}

.tlui-row {
  flex-direction: row;
  padding: 0 2px;
  display: flex;
}

.tlui-row > * {
  margin-left: -2px;
  margin-right: -2px;
}

.tlui-column {
  flex-direction: column;
  padding: 2px 0;
  display: flex;
}

.tlui-column > * {
  margin-top: -2px;
  margin-bottom: -2px;
}

.tlui-grid {
  grid-template-columns: repeat(4, 1fr);
  grid-auto-flow: row;
  padding: 2px;
  display: grid;
  overflow: hidden;
}

.tlui-grid > * {
  margin: -2px;
}

.tlui-zoom-menu__button {
  text-align: center;
  width: 60px;
  min-width: 60px;
}

.tlui-zoom-menu__button[data-state="open"]:after {
  background: linear-gradient(0deg, #90909000 0%, var(--tl-color-muted-2) 100%);
  opacity: 1;
}

.tlui-layout {
  pointer-events: none;
  -webkit-user-select: none;
  user-select: none;
  contain: strict;
  height: 100%;
  max-height: 100%;
  z-index: var(--tl-layer-panels);
  --tl-sab: env(safe-area-inset-bottom);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-smooth: antialiased;
  text-rendering: optimizelegibility;
  grid-template-rows: minmax(0, 1fr) auto;
  grid-template-columns: 1fr;
  grid-auto-rows: auto;
  font-weight: 500;
  line-height: 1.6;
  display: grid;
  position: relative;
  overflow: clip;
  transform: translate3d(0, 0, 0);
}

.tlui-layout__top {
  grid-area: 1 / 1;
  justify-content: space-between;
  min-width: 0;
  display: flex;
}

.tlui-layout__top__left {
  flex-direction: column;
  flex: 0 1 0;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  height: 100%;
  display: flex;
}

.tlui-layout__top__right {
  flex-direction: column;
  flex: none;
  justify-content: flex-start;
  align-items: flex-end;
  min-width: 0;
  height: 100%;
  display: flex;
}

.tlui-scrollable, .tlui-scrollable * {
  pointer-events: all;
  touch-action: auto;
  overscroll-behavior: none;
}

.tlui-helper-buttons {
  justify-content: flex-start;
  align-items: flex-start;
  gap: var(--tl-space-3);
  width: min-content;
  margin: var(--tl-space-2) var(--tl-space-3);
  white-space: nowrap;
  pointer-events: none;
  z-index: var(--tl-layer-panels);
  flex-direction: column;
  display: flex;
  position: relative;
}

.tlui-icon {
  background-color: currentColor;
  flex-shrink: 0;
  width: 18px;
  height: 18px;
}

.tlui-icon__placeholder {
  background-color: #0000;
  flex-shrink: 0;
  width: 18px;
  height: 18px;
}

.tlui-icon__small {
  width: 15px;
  height: 15px;
}

.tlui-icon__tiny {
  width: 12px;
  height: 12px;
}

.tlui-slider__container {
  width: 100%;
  padding: 0px var(--tl-space-4);
}

.tlui-slider {
  -webkit-user-select: none;
  user-select: none;
  touch-action: none;
  align-items: center;
  width: 100%;
  display: flex;
  position: relative;
}

.tlui-slider__track {
  cursor: pointer;
  flex-grow: 1;
  height: 44px;
  position: relative;
}

.tlui-slider__track:after {
  content: "";
  background-color: var(--tl-color-muted-1);
  border-radius: 14px;
  width: 100%;
  height: 3px;
  display: block;
  position: absolute;
  top: calc(50% - 2px);
}

.tlui-slider__range {
  background-color: var(--tl-color-selected);
  border-radius: 14px;
  height: 3px;
  position: absolute;
  top: calc(50% - 2px);
  left: 0;
}

.tlui-slider__thumb {
  all: unset;
  cursor: grab;
  background-color: var(--tl-color-panel);
  width: 18px;
  height: 18px;
  box-shadow: inset 0px 0px 0px 2px var(--tl-color-text-1);
  border-radius: 999px;
  display: block;
  position: relative;
  top: -1px;
}

.tlui-slider__thumb:active {
  cursor: grabbing;
  box-shadow: inset 0px 0px 0px 2px var(--tl-color-text-1),
		var(--tl-shadow-1);
}

.tlui-input {
  z-index: var(--tl-layer-above);
  height: 40px;
  max-height: 40px;
  font-family: inherit;
  font-size: 12px;
  font-weight: inherit;
  color: var(--tl-color-text-1);
  padding: var(--tl-space-4);
  text-overflow: ellipsis;
  -webkit-user-select: all;
  user-select: all;
  text-rendering: optimizelegibility;
  background: none;
  border: none;
  outline: none;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin: 0;
  padding-left: 0;
  display: flex;
  position: relative;
  -webkit-user-select: auto !important;
}

.tlui-input::placeholder {
  color: var(--tl-color-text-3);
}

.tlui-input__wrapper {
  align-items: center;
  gap: var(--tl-space-4);
  width: 100%;
  height: 44px;
  color: var(--tl-color-text);
  display: flex;
}

.tlui-input__wrapper > .tlui-icon {
  flex-shrink: 0;
}

@supports (-webkit-touch-callout: none) {
  .tlui-input {
    font-size: 16px;
  }
}

.tlui-select__trigger {
  justify-content: space-between;
  gap: var(--tl-space-3);
}

.tlui-select__trigger[data-state="open"]:after {
  opacity: 1;
}

.tlui-select__value {
  align-items: center;
  gap: var(--tl-space-2);
  display: flex;
}

.tlui-select__chevron {
  color: var(--tl-color-text-2);
  flex-shrink: 0;
}

.tlui-select__content {
  min-width: var(--radix-select-trigger-width);
  max-height: var(--radix-select-content-available-height);
}

.tlui-select__viewport {
  padding: 4px 0;
}

.tlui-select__item {
  justify-content: flex-start;
}

.tlui-select__item-indicator {
  visibility: hidden;
}

.tlui-select__item[data-state="checked"] .tlui-select__item-indicator {
  visibility: visible;
}

.tlui-kbd {
  justify-items: center;
  align-self: bottom;
  color: currentColor;
  grid-template-columns: auto;
  grid-auto-columns: minmax(1em, auto);
  grid-auto-flow: column;
  margin-inline-start: var(--tl-space-4);
  font-family: inherit;
  font-size: 11px;
  line-height: 11px;
  display: grid;
}

.tlui-kbd > span {
  text-align: center;
  border-radius: 2px;
  width: 100%;
  margin: 0;
  padding: 2px;
  display: inline;
}

.tlui-kbd > span:last-child {
  padding-inline-end: 0;
}

.tlui-kbd:not(:last-child) {
  margin-inline-end: var(--tl-space-2);
}

.tlui-focus-button {
  z-index: var(--tl-layer-panels);
  pointer-events: all;
}

.tlui-menu:empty {
  display: none;
}

.tlui-menu {
  z-index: var(--tl-layer-menus);
  border-radius: var(--tl-radius-3);
  pointer-events: all;
  touch-action: auto;
  overscroll-behavior: none;
  background-color: var(--tl-color-panel);
  width: fit-content;
  height: fit-content;
  box-shadow: var(--tl-shadow-3);
  overflow-y: auto;
}

@media (max-height: 600px) {
  .tlui-menu {
    max-height: 70vh;
  }
}

.tlui-menu::-webkit-scrollbar {
  display: none;
}

.tlui-menu__group {
  width: 100%;
}

.tlui-menu__group:empty {
  display: none;
}

.tlui-menu__group {
  border-bottom: 1px solid var(--tl-color-divider);
}

.tlui-menu__group:last-of-type {
  border-bottom: none;
}

.tlui-menu__submenu__trigger {
  --gradient-angle: 90deg;
}

.tlui-menu__submenu__trigger[data-direction="left"] {
  --gradient-angle: 270deg;
}

.tlui-menu__submenu__trigger[data-state="open"]:after {
  opacity: 1;
  background: linear-gradient(var(--gradient-angle),
		#90909000 0%,
		var(--tl-color-muted-2) 100%);
}

@media (hover: hover) {
  .tlui-menu__submenu__trigger:is(:hover, [data-state="open"]):after {
    opacity: 1;
    background: linear-gradient(var(--gradient-angle),
			#90909000 0%,
			var(--tl-color-muted-2) 100%);
  }
}

.tlui-menu[data-size="large"] > .tlui-menu__group {
  min-width: initial;
}

.tlui-menu[data-size="medium"] > .tlui-menu__group {
  min-width: 144px;
}

.tlui-menu[data-size="small"] > .tlui-menu__group {
  min-width: 96px;
}

.tlui-menu[data-size="tiny"] > .tlui-menu__group {
  min-width: 0;
}

.tlui-menu-click-capture {
  z-index: var(--tl-layer-menu-click-capture);
  position: fixed;
  inset: 0;
}

.tlui-popover {
  align-content: stretch;
  display: flex;
  position: relative;
}

.tlui-popover__content {
  max-height: calc(var(--radix-popover-content-available-height) - 8px);
  border-radius: var(--tl-radius-3);
  background-color: var(--tl-color-panel);
  box-shadow: var(--tl-shadow-3);
  z-index: var(--tl-layer-menus);
  touch-action: auto;
  overscroll-behavior: none;
  scrollbar-width: none;
  -ms-overflow-style: none;
  border: none;
  margin: 0;
  position: relative;
  overflow: hidden auto;
}

.tlui-menu-zone {
  z-index: var(--tl-layer-panels);
  border-right: 2px solid var(--tl-color-background);
  border-bottom: 2px solid var(--tl-color-background);
  border-bottom-right-radius: var(--tl-radius-4);
  background-color: var(--tl-color-low);
  width: fit-content;
  position: relative;
}

.tlui-menu-zone [data-state="open"]:after {
  background: linear-gradient(180deg, #90909000 0%, var(--tl-color-muted-2) 100%);
  opacity: 1;
}

@media (hover: hover) {
  .tlui-menu-zone [data-state="open"]:not(:hover):after {
    background: linear-gradient(180deg, #90909000 0%, var(--tl-color-muted-2) 100%);
    opacity: 1;
  }
}

.tlui-page-menu__wrapper {
  flex-direction: column;
  width: 220px;
  display: flex;
}

.tlui-page-menu__trigger {
  width: auto;
}

.tlui-page-menu__trigger[data-state="open"]:after {
  background: linear-gradient(180deg, #90909000 0%, var(--tl-color-muted-2) 100%);
  opacity: 1;
}

.tlui-page-menu__list {
  scrollbar-width: none;
  -ms-overflow-style: none;
  flex: none;
  overflow: hidden auto;
}

.tlui-page-menu__list::-webkit-scrollbar {
  display: none;
}

.tlui-page-menu__list__content {
  position: relative;
  overflow: hidden;
}

.tlui-page-menu__resize-handle {
  cursor: ns-resize;
  touch-action: none;
  background: var(--tl-color-divider);
  z-index: 999;
  flex: none;
  height: 1px;
  transition: background-color .15s ease-in-out 80ms;
  position: relative;
}

.tlui-page-menu__resize-handle:after {
  content: "";
  z-index: 2000;
  pointer-events: all;
  background: none;
  position: absolute;
  inset: -4px 0;
}

.tlui-page-menu__resize-handle:before {
  content: "";
  pointer-events: none;
  z-index: 2001;
  background: none;
  height: 1.5px;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
}

.tlui-page-menu__resize-handle[data-resizing="true"]:before {
  background: var(--tl-color-selected);
  transition: none;
}

.tlui-page-menu__create-button {
  flex: none;
  margin: 0;
}

.tlui-page-menu__item__button {
  flex: auto;
  min-width: 0;
}

.tlui-page-menu__item__button:after, .tlui-page-menu__item__drag-handle:after {
  content: none;
}

.tlui-page-menu__item__button > .tlui-button__label {
  padding-inline-end: 28px;
}

.tlui-page-menu__item {
  top: 0;
  flex-direction: row;
  align-items: center;
  width: 100%;
  height: 40px;
  transition: transform 80ms ease-out;
  display: flex;
  position: absolute;
  inset-inline-start: 0;
  overflow: hidden;
}

.tlui-page-menu__item:before {
  content: "";
  border-radius: var(--tl-radius-2);
  background: var(--tl-color-muted-2);
  opacity: 0;
  pointer-events: none;
  position: absolute;
  inset: 4px;
}

.tlui-page-menu__item > * {
  z-index: var(--tl-layer-above);
  position: relative;
}

.tlui-page-menu__item[data-iscurrent="true"]:not([data-editing="true"]):before {
  background: var(--tl-color-hint);
  opacity: 1;
}

.tlui-page-menu__item__title {
  flex: 1;
  height: 40px;
  position: relative;
}

.tlui-page-menu__item__title:before {
  content: "";
  border-radius: var(--tl-radius-2);
  border: 1px solid var(--tl-color-primary);
  pointer-events: none;
  position: absolute;
  inset: 4px;
}

.tlui-page-menu__item__title > .tlui-input__wrapper {
  height: 100%;
}

.tlui-page-menu__item[data-dragging="true"], .tlui-page-menu__item[data-dragging="true"] .tlui-page-menu__item__button, .tlui-page-menu__item[data-dragging="true"] .tlui-page-menu__item__drag-handle {
  cursor: grabbing;
  transition: none;
}

.tlui-page-menu__item[data-dragging="true"] {
  background: var(--tl-color-panel);
  opacity: 1;
}

.tlui-page-menu__item__drag-handle {
  min-width: 32px;
  color: var(--tl-color-text-3);
  cursor: grab;
  touch-action: none;
  flex: 0 0 32px;
  padding: 0;
}

.tlui-page-menu__item__drag-handle > .tlui-icon {
  position: relative;
  inset-inline-start: 1px;
}

.tlui-page-menu__item__drag-handle + .tlui-page-menu__item__button {
  padding-inline-start: 0;
}

.tlui-page-menu__item__input {
  margin-inline-start: 12px;
}

.tlui-page-menu__item__submenu {
  inset-inline-end: 0;
  z-index: 10;
  height: 100%;
  position: absolute;
  top: 0;
}

.tlui-page-menu__item__submenu > .tlui-button {
  opacity: 0;
  color: var(--tl-color-text-3);
}

.tlui-page-menu__item__submenu > .tlui-button:after {
  content: none;
}

:is(.tlui-page-menu__item:has(.tlui-button:focus-visible) > .tlui-page-menu__item__submenu > .tlui-button, .tlui-page-menu__item__submenu > .tlui-button[data-state="open"], .tlui-page-menu__item__submenu > .tlui-button:focus-visible) {
  opacity: 1;
}

.tlui-page-menu__list__content[data-dragging="true"] .tlui-page-menu__item > .tlui-page-menu__item__submenu > .tlui-button {
  opacity: 0;
}

.tl-container[data-coarse="true"] .tlui-page-menu__item__submenu > .tlui-button {
  opacity: 1;
}

.tl-container[data-coarse="true"] .tlui-page-menu__item__button > .tlui-button__label {
  padding-inline-end: 28px;
}

@media (hover: hover) {
  .tlui-page-menu__resize-handle:hover:before {
    background: var(--tl-color-selected);
    height: 2px;
    transition: background-color .15s 80ms;
  }

  .tlui-page-menu__item:not([data-editing="true"]):hover:before, .tlui-page-menu__item:hover > .tlui-page-menu__item__submenu > .tlui-button {
    opacity: 1;
  }

  .tlui-page-menu__item__button > .tlui-button__label {
    padding-inline-end: 0;
  }

  .tlui-page-menu__item:hover > .tlui-page-menu__item__button > .tlui-button__label {
    padding-inline-end: 28px;
  }

  .tlui-page-menu__item__submenu > .tlui-button:hover {
    color: var(--tl-color-text);
  }
}

.tl-skip-to-main-content {
  z-index: var(--tl-layer-toasts);
  padding: 8px 16px;
  position: fixed;
  top: 48px;
  left: -9999px;
}

.tl-skip-to-main-content:focus {
  left: 8px;
}

.tl-skip-to-main-content:focus + .tlui-layout__top .tlui-helper-buttons {
  display: none;
}

.tlui-offline-indicator {
  color: var(--tl-color-background);
  background-color: var(--tl-color-text);
  cursor: default;
  opacity: 0;
  border: none;
  border-radius: 99px;
  justify-content: center;
  align-items: center;
  width: 32px;
  height: 32px;
  animation: .12s 2s forwards tl-fade-in;
  display: flex;
}

.tlui-style-panel__wrapper {
  box-shadow: var(--tl-shadow-2);
  border-radius: var(--tl-radius-3);
  pointer-events: all;
  background-color: var(--tl-color-panel);
  margin: 8px;
  touch-action: auto;
  overscroll-behavior: none;
  height: fit-content;
  max-height: 100%;
  color: var(--tl-color-text);
  margin-top: 4px;
  overflow: hidden auto;
}

.tlui-style-panel__wrapper:only-child {
  margin-top: 8px;
}

.tlui-style-panel {
  z-index: var(--tl-layer-panels);
  pointer-events: all;
  width: 148px;
  max-width: 148px;
  position: relative;
}

.tlui-style-panel[data-enhanced-a11y-mode="true"] .tlui-button[data-isactive="true"] {
  outline: 2px solid var(--tl-color-text);
  outline-offset: -5px;
  border-radius: 10px;
}

.tlui-style-panel::-webkit-scrollbar {
  display: none;
}

.tlui-style-panel .tlui-button.select {
  width: 100%;
}

.tlui-style-panel__section {
  flex-direction: column;
  display: flex;
  position: relative;
}

.tlui-style-panel__section:not(:nth-last-child(-n+1 of .tlui-style-panel__section:not(:empty))) {
  border-bottom: 1px solid var(--tl-color-divider);
}

.tlui-style-panel__section:has(.tlui-slider__container:last-child):not(:nth-last-child(-n+1 of .tlui-style-panel__section:not(:empty))) {
  margin-bottom: 7px;
}

.tlui-style-panel__section:empty {
  display: none;
}

.tlui-style-panel__section .tlui-toolbar:has(.tlui-toolbar) {
  flex-wrap: wrap;
}

.tlui-style-panel__section .tlui-toolbar:has(.tlui-toolbar) .tlui-style-panel__subheading {
  margin-left: -2px;
}

.tlui-style-panel__section__common:not(:only-child) {
  border-bottom: 1px solid var(--tl-color-divider);
  margin-bottom: 7px;
}

.tlui-toolbar-toggle-group-item, .tlui-style-panel__dropdown-picker > .tlui-button__icon {
  width: 40px;
  padding: 0;
}

.tlui-style-panel__dropdown-picker:only-child {
  flex: 1;
}

.tlui-style-panel__double-select-picker {
  padding-left: var(--tl-space-4);
  color: var(--tl-color-text-1);
  grid-template-columns: 1fr auto;
  align-items: center;
  font-size: 12px;
  display: flex;
}

.tlui-style-panel__double-select-picker-label {
  text-overflow: ellipsis;
  white-space: nowrap;
  flex-grow: 2;
  max-width: 100%;
  overflow: hidden;
}

.tlui-style-panel .tlui-button[data-state="open"]:after {
  opacity: 1;
  background: linear-gradient(270deg, #90909000 0%, var(--tl-color-muted-2) 100%);
}

@media (hover: hover) {
  .tlui-style-panel .tlui-button[aria-expanded="true"] {
    background: none;
  }

  .tlui-style-panel .tlui-button[data-state="open"]:not(:hover):after {
    opacity: 1;
    background: linear-gradient(270deg, #90909000 0%, var(--tl-color-muted-2) 100%);
  }
}

.tlui-style-panel__section .tlui-style-panel__subheading, .tlui-style-panel__section__common .tlui-style-panel__subheading, .tlui-style-panel__subheading + .tlui-slider__container {
  padding: var(--tl-space-2) var(--tl-space-3) 0px var(--tl-space-4);
  font-size: 12px;
  font-weight: inherit;
  line-height: inherit;
  margin: 0;
}

.tlui-style-panel .tlui-style-panel__subheading:first-of-type {
  padding-top: var(--tl-space-3);
}

.tlui-style-panel__subheading + .tlui-slider__container {
  padding-top: 0;
}

.tlui-layout__bottom {
  grid-row: 2;
  width: 100%;
}

.tlui-layout__bottom__main {
  justify-content: center;
  align-items: flex-end;
  width: 100%;
  display: flex;
}

.tlui-navigation-panel {
  width: min-content;
  z-index: var(--tl-layer-panels);
  pointer-events: all;
  flex-direction: column;
  display: flex;
  position: absolute;
  left: 0;
}

.tl-container[dir="rtl"] .tlui-navigation-panel {
  left: auto;
  right: 0;
}

.tlui-navigation-panel:before {
  content: "";
  z-index: -1;
  border-top: 2px solid var(--tl-color-background);
  border-right: 2px solid var(--tl-color-background);
  border-radius: 0;
  border-top-right-radius: var(--tl-radius-4);
  background-color: var(--tl-color-low);
  display: block;
  position: absolute;
  inset: -2px -2px 0 0;
}

.tl-container[dir="rtl"] .tlui-navigation-panel:before {
  border-right: 0;
  border-left: 2px solid var(--tl-color-background);
  border-top-right-radius: 0;
  border-top-left-radius: var(--tl-radius-4);
  inset: -2px 0 0 -2px;
}

.tlui-navigation-panel[data-a11y="true"]:before {
  display: none;
}

.tlui-minimap {
  width: 100%;
  height: 96px;
  min-height: 96px;
  padding: var(--tl-space-3);
  padding-top: 0;
  overflow: hidden;
}

.tlui-minimap__canvas {
  width: 100%;
  height: 100%;
  position: relative;
}

.tlui-main-toolbar {
  flex-grow: 2;
  grid-area: 1 / 1 / auto / span 3;
  justify-content: center;
  align-items: center;
  display: flex;
}

.tlui-main-toolbar--horizontal {
  padding-bottom: calc(var(--tl-space-3) + var(--tl-sab));
  max-width: 100%;
}

.tlui-main-toolbar--vertical {
  padding-left: calc(var(--tl-space-3) + var(--tl-sab));
  position: absolute;
  top: 90px;
  bottom: 140px;
  left: 0;
}

[data-breakpoints-below*="6"] .tlui-main-toolbar--vertical {
  bottom: 90px;
}

.tlui-main-toolbar__inner {
  gap: var(--tl-space-3);
  align-items: flex-start;
  width: fit-content;
  display: flex;
  position: relative;
}

.tlui-main-toolbar--vertical .tlui-main-toolbar__inner {
  flex-direction: column;
}

.tlui-main-toolbar--horizontal .tlui-main-toolbar__left {
  width: fit-content;
}

.tlui-main-toolbar--vertical .tlui-main-toolbar__left {
  height: fit-content;
  display: flex;
}

.tlui-main-toolbar__extras {
  z-index: var(--tl-layer-above);
  pointer-events: none;
  align-self: stretch;
  position: relative;
}

.tlui-main-toolbar__extras:empty {
  display: none;
}

.tlui-main-toolbar--horizontal .tlui-main-toolbar__extras {
  height: 48px;
  top: 6px;
}

.tlui-main-toolbar--vertical .tlui-main-toolbar__extras {
  order: 1;
  width: 48px;
}

.tlui-main-toolbar__extras__controls {
  z-index: var(--tl-layer-above);
  background-color: var(--tl-color-low);
  border: 2px solid var(--tl-color-background);
  pointer-events: all;
  position: relative;
}

.tlui-main-toolbar--horizontal .tlui-main-toolbar__extras__controls {
  border-top-left-radius: var(--tl-radius-4);
  border-top-right-radius: var(--tl-radius-4);
  width: fit-content;
  margin-left: 8px;
  margin-right: 0;
}

.tlui-main-toolbar--vertical .tlui-main-toolbar__extras__controls {
  border-top-right-radius: var(--tl-radius-4);
  border-bottom-right-radius: var(--tl-radius-4);
  width: fit-content;
  margin-top: 8px;
  margin-bottom: 0;
  margin-left: -2px;
}

.tlui-main-toolbar__tools {
  border-radius: var(--tl-radius-4);
  z-index: var(--tl-layer-panels);
  pointer-events: all;
  background: var(--tl-color-panel);
  box-shadow: var(--tl-shadow-2);
  contain: layout style paint;
  position: relative;
}

.tlui-main-toolbar--horizontal .tlui-main-toolbar__mobile-style-panel {
  align-self: flex-end;
}

.tlui-main-toolbar--vertical .tlui-main-toolbar__mobile-style-panel {
  align-self: flex-start;
}

.tlui-main-toolbar--horizontal .tlui-main-toolbar__overflow {
  width: 40px;
  margin-left: 2px;
}

.tlui-main-toolbar--vertical .tlui-main-toolbar__overflow {
  height: 40px;
  margin-top: 2px;
}

.tlui-layout__mobile .tlui-main-toolbar--horizontal .tlui-main-toolbar__overflow {
  width: 32px;
  padding: 0;
}

.tlui-main-toolbar--horizontal [data-state="open"]:after {
  background: linear-gradient(0deg, #90909000 0%, var(--tl-color-muted-2) 100%);
  opacity: 1;
}

.tlui-main-toolbar--vertical [data-state="open"]:after {
  background: linear-gradient(90deg, #90909000 0%, var(--tl-color-muted-2) 100%);
  opacity: 1;
}

.tlui-main-toolbar__overflow-content {
  touch-action: none;
}

.tlui-main-toolbar__tools [data-toolbar-visible="false"], .tlui-main-toolbar__overflow-content [data-toolbar-visible="false"], .tlui-main-toolbar__group:empty {
  display: none;
}

.tlui-row.tlui-main-toolbar__group:not(:nth-last-child(-n+1 of [data-toolbar-visible="true"])) {
  border-right: 1px solid var(--tl-color-divider);
  margin-right: 2px;
}

.tlui-column.tlui-main-toolbar__group:not(:nth-last-child(-n+1 of [data-toolbar-visible="true"])) {
  border-bottom: 1px solid var(--tl-color-divider);
  margin-bottom: 2px;
}

.tlui-grid.tlui-main-toolbar__group {
  grid-column: 1 / span 4;
}

.tlui-grid.tlui-main-toolbar__group:not(:nth-last-child(-n+1 of [data-toolbar-visible="true"])) {
  border-bottom: 1px solid var(--tl-color-divider);
  margin-bottom: 2px;
}

@media (hover: hover) {
  .tlui-main-toolbar--horizontal [data-state="open"]:not(:hover):after {
    background: linear-gradient(0deg, #90909000 0%, var(--tl-color-muted-2) 100%);
    opacity: 1;
  }

  .tlui-main-toolbar--vertical [data-state="open"]:not(:hover):after {
    background: linear-gradient(90deg, #90909000 0%, var(--tl-color-muted-2) 100%);
    opacity: 1;
  }
}

.tlui-tooltip {
  background-color: var(--tl-color-tooltip);
  box-shadow: none;
  color: var(--tl-color-text-shadow);
  text-align: center;
  will-change: transform, opacity;
  z-index: 2;
  border-radius: 4px;
  width: fit-content;
  max-width: 400px;
  padding: 2px 8px;
  font-size: 12px;
}

.tlui-tooltip__arrow {
  fill: var(--tl-color-tooltip);
  will-change: opacity;
}

[data-radix-popper-content-wrapper]:has(.tlui-tooltip) {
  pointer-events: none;
  z-index: var(--tl-layer-toasts) !important;
}

.tlui-debug-panel {
  background-color: var(--tl-color-low);
  width: 100%;
  border-top: 1px solid var(--tl-color-background);
  color: var(--tl-color-text-1);
  z-index: var(--tl-layer-panels);
  pointer-events: all;
  grid-template-columns: 1fr auto auto auto;
  justify-content: space-between;
  align-items: center;
  padding-inline-start: var(--tl-space-4);
  font-size: 12px;
  display: grid;
}

.tlui-debug-panel__current-state {
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}

.tlui-debug-panel__fps {
  margin-right: 8px;
}

.tlui-debug-panel__fps__slow {
  color: var(--tl-color-danger);
  font-weight: bold;
}

.tlui-a11y-audit {
  border-collapse: collapse;
}

.tlui-a11y-audit th, .tlui-a11y-audit td {
  border: 1px solid var(--tl-color-low-border);
  padding: 8px;
}

.tlui-toast__viewport {
  justify-content: flex-end;
  align-items: flex-end;
  gap: var(--tl-space-3);
  pointer-events: none;
  padding: 0px var(--tl-space-3) 64px 0px;
  z-index: var(--tl-layer-toasts);
  flex-direction: column;
  margin: 0;
  display: flex;
  position: absolute;
  inset: 0;
}

.tl-container[dir="rtl"] .tlui-toast__viewport {
  padding: 0px 0px 64px var(--tl-space-3);
}

.tlui-toast__viewport > * {
  pointer-events: all;
}

.tlui-toast__icon {
  padding-top: 11px;
  color: var(--tl-color-text-1);
  padding-inline-start: var(--tl-space-4);
}

.tlui-toast__container {
  background-color: var(--tl-color-panel);
  min-width: 200px;
  box-shadow: var(--tl-shadow-2);
  border-radius: var(--tl-radius-3);
  flex-direction: row;
  font-size: 12px;
  display: flex;
}

.tlui-toast__container[data-severity="success"] .tlui-icon {
  color: var(--tl-color-success);
}

.tlui-toast__container[data-severity="info"] .tlui-icon {
  color: var(--tl-color-info);
}

.tlui-toast__container[data-severity="warning"] .tlui-icon {
  color: var(--tl-color-warning);
}

.tlui-toast__container[data-severity="error"] .tlui-icon {
  color: var(--tl-color-danger);
}

.tlui-toast__main {
  flex-grow: 2;
  max-width: 280px;
}

.tlui-toast__content {
  padding: var(--tl-space-4);
  gap: var(--tl-space-3);
  flex-direction: column;
  line-height: 1.4;
  display: flex;
}

.tlui-toast__main[data-actions="true"] .tlui-toast__content {
  padding-bottom: var(--tl-space-2);
}

.tlui-toast__title {
  color: var(--tl-color-text-1);
  font-weight: bold;
  line-height: 16px;
}

.tlui-toast__description {
  color: var(--tl-color-text-1);
  padding: var(--tl-space-3);
  margin: 0;
  padding: 0;
}

.tlui-toast__icon + .tlui-toast__main > .tlui-toast__actions {
  padding-left: 0;
}

.tlui-toast__actions {
  flex-direction: row;
  justify-content: flex-start;
  margin-left: 0;
  display: flex;
}

.tlui-toast__close {
  flex-shrink: 0;
  align-self: flex-end;
}

@media (prefers-reduced-motion: no-preference) {
  .tlui-toast__container[data-state="open"] {
    animation: .2s cubic-bezier(.785, .135, .15, .86) tlui-slide-in;
  }

  .tlui-toast__container[data-state="closed"] {
    animation: .1s ease-in tlui-fade-out;
  }

  .tlui-toast__container[data-swipe="move"] {
    transform: translateX(var(--radix-toast-swipe-move-x));
  }

  .tlui-toast__container[data-swipe="cancel"] {
    transition: transform .2s ease-out;
    transform: translateX(0);
  }

  .tlui-toast__container[data-swipe="end"] {
    animation: .1s ease-out tlui-slide-out;
  }

  .tl-container[dir="rtl"] .tlui-toast__container[data-state="open"] {
    animation: .2s cubic-bezier(.785, .135, .15, .86) tlui-slide-in-rtl;
  }

  .tl-container[dir="rtl"] .tlui-toast__container[data-state="closed"] {
    animation: .1s ease-in tlui-fade-out;
  }

  .tl-container[dir="rtl"] .tlui-toast__container[data-swipe="end"] {
    animation: .1s ease-out tlui-slide-out-rtl;
  }
}

.tlui-dialog__overlay {
  width: 100%;
  height: 100%;
  z-index: var(--tl-layer-canvas-overlays);
  background-color: var(--tl-color-overlay);
  animation: .12s ease-out tl-fade-in;
  position: absolute;
  top: 0;
  left: 0;
}

.tlui-dialog__positioner {
  width: 100%;
  height: 100%;
  z-index: var(--tl-layer-canvas-overlays);
  pointer-events: all;
  padding: 0px var(--tl-space-3);
  place-items: center;
  display: grid;
  position: absolute;
  top: 0;
  left: 0;
  overflow-y: auto;
}

.tlui-dialog__content {
  cursor: default;
  background-color: var(--tl-color-panel);
  box-shadow: var(--tl-shadow-3);
  border-radius: var(--tl-radius-3);
  flex-direction: column;
  min-width: 300px;
  max-width: 100%;
  max-height: 80%;
  font-size: 12px;
  display: flex;
  position: relative;
  overflow: hidden;
}

.tlui-dialog__header {
  z-index: var(--tl-layer-header-footer);
  color: var(--tl-color-text);
  flex: 0;
  align-items: center;
  height: 40px;
  padding-inline-start: var(--tl-space-4);
  display: flex;
  position: relative;
}

.tlui-dialog__header__title {
  font-weight: inherit;
  color: var(--tl-color-text-1);
  flex: 1;
  margin: 0;
  font-size: 12px;
}

.tlui-dialog__header__close {
  justify-self: flex-end;
}

.tlui-dialog__body {
  padding: var(--tl-space-4) var(--tl-space-4);
  color: var(--tl-color-text-1);
  -webkit-user-select: text;
  user-select: text;
  flex: 0;
  overflow: hidden auto;
}

.tlui-dialog__body a {
  color: var(--tl-color-selected);
}

.tlui-dialog__body ul, .tlui-dialog__body ol {
  gap: var(--tl-space-2);
  flex-direction: column;
  padding-left: 16px;
  display: flex;
}

.tlui-dialog__footer {
  min-height: 12px;
  z-index: var(--tl-layer-header-footer);
  position: relative;
}

.tlui-dialog__footer__actions {
  justify-content: flex-end;
  align-items: center;
  display: flex;
}

.tlui-dialog__footer__actions > .tlui-button:nth-last-child(n+2) {
  margin-right: -4px;
}

.tlui-edit-link-dialog {
  gap: var(--tl-space-4);
  color: var(--tl-color-text);
  flex-direction: column;
  display: flex;
}

.tlui-edit-link-dialog__input {
  background-color: var(--tl-color-muted-2);
  border-radius: var(--tl-radius-2);
  padding: 0px var(--tl-space-4);
  flex-grow: 2;
}

.tlui-embed__spacer {
  min-height: 0;
  margin-left: calc(-1 * var(--tl-space-4));
  margin-top: calc(-1 * var(--tl-space-4));
  pointer-events: none;
  flex-grow: 2;
}

.tlui-embed-dialog__list {
  padding: 0px var(--tl-space-3) var(--tl-space-4) var(--tl-space-3);
  flex-direction: column;
  display: flex;
}

.tlui-embed-dialog__item__image {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  background-color: var(--tl-color-selected-contrast);
  border-radius: var(--tl-radius-1);
  justify-content: center;
  align-items: center;
  width: 24px;
  height: 24px;
  display: flex;
}

.tlui-embed-dialog__enter {
  gap: var(--tl-space-4);
  color: var(--tl-color-text-1);
  flex-direction: column;
  display: flex;
}

.tlui-embed-dialog__input {
  background-color: var(--tl-color-muted-2);
  border-radius: var(--tl-radius-2);
  padding: 0px var(--tl-space-4);
  flex-grow: 2;
}

.tlui-embed-dialog__warning {
  color: var(--tl-color-danger);
  text-shadow: none;
}

.tlui-embed-dialog__instruction__link {
  gap: var(--tl-space-1);
  margin-top: var(--tl-space-4);
  display: flex;
}

.tlui-embed-dialog__enter a {
  color: var(--tl-color-text-1);
}

.tlui-shortcuts-dialog__header {
  border-bottom: 1px solid var(--tl-color-divider);
}

.tlui-shortcuts-dialog__body {
  columns: 3;
  column-gap: var(--tl-space-9);
  pointer-events: all;
  touch-action: auto;
  scrollbar-width: none;
  position: relative;
  overflow-x: auto;
}

.tlui-shortcuts-dialog__body::-webkit-scrollbar {
  display: none;
}

.tlui-shortcuts-dialog__body__tablet {
  columns: 2;
}

.tlui-shortcuts-dialog__body__mobile {
  columns: 1;
}

.tlui-shortcuts-dialog__group {
  break-inside: avoid-column;
  padding-bottom: var(--tl-space-6);
}

.tlui-shortcuts-dialog__group__title {
  font-size: inherit;
  font-weight: inherit;
  color: var(--tl-color-text-3);
  align-items: center;
  height: 32px;
  margin: 0;
  display: flex;
}

.tlui-shortcuts-dialog__group__content {
  color: var(--tl-color-text-1);
  flex-direction: column;
  display: flex;
}

.tlui-shortcuts-dialog__key-pair {
  gap: var(--tl-space-4);
  justify-content: space-between;
  align-items: center;
  height: 32px;
  display: flex;
}

.tlui-shortcuts-dialog__key-pair__key {
  flex: 1;
  font-size: 12px;
}

.tlui-language-menu {
  max-height: 500px;
}

.tlui-language-menu:after {
  content: "";
  background: linear-gradient(to bottom,
		var(--tl-color-panel-transparent) 0%,
		var(--tl-color-panel) 90%,
		var(--tl-color-panel) 100%);
  border-bottom-left-radius: var(--tl-radius-3);
  border-bottom-right-radius: var(--tl-radius-3);
  pointer-events: none;
  height: 24px;
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
}

.tlui-actions-menu {
  max-height: calc(100vh - 150px);
}

.tlui-help-menu {
  pointer-events: all;
  bottom: var(--tl-space-2);
  right: var(--tl-space-2);
  z-index: var(--tl-layer-panels);
  border: 2px solid var(--tl-color-background);
  border-radius: 100%;
  position: absolute;
}

.tlui-share-zone {
  z-index: var(--tl-layer-panels);
  flex-direction: row;
  justify-content: flex-end;
  align-items: center;
  padding: 2px 4px 0 0;
  display: flex;
}

.tlui-people-menu__avatars-button {
  cursor: pointer;
  pointer-events: all;
  border-radius: var(--tl-radius-1);
  background: none;
  border: none;
  justify-content: flex-end;
  align-items: center;
  height: 100%;
  padding-right: 1px;
  display: flex;
}

.tlui-people-menu__avatars {
  flex-direction: row;
  display: flex;
}

.tlui-people-menu__avatar {
  border: 2px solid var(--tl-color-background);
  background-color: var(--tl-color-low);
  text-align: center;
  width: 24px;
  height: 24px;
  color: var(--tl-color-selected-contrast);
  z-index: 2;
  border-radius: 100%;
  justify-content: center;
  align-items: center;
  font-size: 10px;
  font-weight: bold;
  display: flex;
  position: relative;
}

.tlui-people-menu__avatar:nth-of-type(n+2) {
  margin-inline-start: -12px;
}

.tlui-people-menu__avatars-button[data-state="open"] {
  opacity: 1;
}

@media (hover: hover) {
  .tlui-people-menu__avatars-button:hover .tlui-people-menu__avatar {
    border-color: var(--tl-color-low);
  }
}

.tlui-people-menu__more {
  min-width: 0;
  color: var(--tl-color-text-1);
  padding: 0 4px;
  font-family: inherit;
  font-size: 11px;
  font-weight: 600;
}

.tlui-people-menu__more:after {
  border-radius: var(--tl-radius-2);
  inset: 0;
}

.tlui-people-menu__wrapper {
  flex-direction: column;
  width: 220px;
  height: fit-content;
  max-height: 50vh;
  display: flex;
  position: relative;
}

.tlui-people-menu__section {
  touch-action: auto;
  touch-action: auto;
  flex-direction: column;
  max-height: 100%;
  position: relative;
  overflow: hidden auto;
}

.tlui-people-menu__section:first-child, .tlui-people-menu__section:last-child {
  flex-shrink: 0;
}

.tlui-people-menu__section:not(:last-child) {
  border-bottom: 1px solid var(--tl-color-divider);
}

.tlui-people-menu__user {
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.tlui-people-menu__user__color {
  flex-shrink: 0;
}

.tlui-people-menu__user__name {
  text-align: start;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--tl-color-text-1);
  flex-grow: 1;
  flex-shrink: 100;
  max-width: 100%;
  font-size: 12px;
  overflow: hidden;
}

.tlui-people-menu__user__label {
  text-align: start;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--tl-color-text-3);
  flex-grow: 100;
  flex-shrink: 0;
  margin-inline-start: 4px;
  font-size: 12px;
  overflow: hidden;
}

.tlui-people-menu__user__input {
  flex-grow: 2;
  height: 100%;
  margin: 0;
  padding: 0;
}

.tlui-people-menu__user > .tlui-input__wrapper {
  align-items: auto;
  flex-grow: 2;
  gap: 8px;
  width: auto;
  height: 100%;
  padding: 0;
  display: flex;
}

.tlui-people-menu__item {
  position: relative;
}

.tlui-people-menu__item:last-of-type .tlui-button__menu {
  margin-bottom: 0;
}

.tlui-people-menu__item__button {
  padding: 0 11px;
  overflow: hidden;
}

.tlui-people-menu__item > .tlui-button__menu {
  align-items: auto;
  flex-grow: 2;
  justify-content: flex-start;
  gap: 11px;
  width: auto;
  display: flex;
}

.tlui-people-menu__name {
  text-align: start;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}

.tlui-people-menu__item__follow {
  top: 0;
  flex-shrink: 0;
  max-width: 40px;
  position: absolute;
  inset-inline-end: 0;
}

.tlui-people-menu__item[data-follow="true"] {
  padding-inline-end: 36px;
}

.tlui-people-menu__item:has(.tlui-button:focus-visible) {
  padding-inline-end: 36px;
}

.tlui-people-menu__item[data-follow="true"] .tlui-people-menu__item__follow {
  opacity: 1;
}

.tlui-people-menu__item:has(.tlui-button:focus-visible) .tlui-people-menu__item__follow {
  opacity: 1;
}

@media (hover: hover) {
  .tlui-people-menu__item__follow {
    opacity: 0;
  }

  .tlui-people-menu__item:hover {
    padding-right: 36px;
  }

  .tlui-people-menu__item:hover .tlui-people-menu__item__follow {
    opacity: 1;
  }
}

.tlui-following-indicator {
  pointer-events: none;
  border-style: solid;
  border-width: 2px;
  display: block;
  position: absolute;
  inset: 0;
}

.tlui-contextual-toolbar {
  position: absolute;
}

.tlui-contextual-toolbar [data-isactive="true"]:after {
  background-color: var(--tl-color-muted-2);
  opacity: 1;
}

.tlui-contextual-toolbar {
  opacity: 0;
  transition: opacity 80ms ease-in-out;
}

.tlui-contextual-toolbar, .tlui-contextual-toolbar * {
  pointer-events: none;
}

.tlui-contextual-toolbar[data-visible="true"] {
  opacity: 1;
  z-index: var(--tl-layer-menus);
}

.tlui-contextual-toolbar[data-interactive="true"], .tlui-contextual-toolbar[data-interactive="true"] * {
  pointer-events: all;
}

.tlui-rich-text__toolbar-link-input {
  width: 148px;
  margin-left: 12px;
}

.tlui-media__toolbar-alt-text-input {
  min-width: 200px;
  margin-left: 12px;
}

.tlui-contextual-toolbar .tlui-input__wrapper {
  height: 40px;
}

.tlui-image__toolbar .tlui-slider__container {
  width: 125px;
}

.tlui-image__toolbar .tlui-slider {
  height: 100%;
}

.tlui-image__toolbar .tlui-slider__track {
  height: 32px;
}

.tlui-image__toolbar .tlui-slider__thumb {
  width: 14px;
  height: 14px;
}

@keyframes tlui-fade-out {
  0% {
    opacity: 1;
  }

  100% {
    opacity: 0;
  }
}

@keyframes tlui-slide-in {
  from {
    transform: translateX(calc(100% + var(--tl-space-3)));
  }

  to {
    transform: translateX(0);
  }
}

@keyframes tlui-slide-out {
  from {
    transform: translateX(var(--radix-toast-swipe-end-x));
  }

  to {
    transform: translateX(calc(100% + var(--tl-space-3)));
  }
}

@keyframes tlui-slide-in-rtl {
  from {
    transform: translateX(calc(-100% - var(--tl-space-3)));
  }

  to {
    transform: translateX(0);
  }
}

@keyframes tlui-slide-out-rtl {
  from {
    transform: translateX(var(--radix-toast-swipe-end-x));
  }

  to {
    transform: translateX(calc(-100% - var(--tl-space-3)));
  }
}

/* [project]/src/app/globals.css [app-client] (css) */
@layer properties {
  @supports (((-webkit-hyphens: none)) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color: rgb(from red r g b)))) {
    :root, :host {
      --shimmer-angle: 20deg;
    }

    *, :before, :after, ::backdrop {
      --tw-translate-x: 0;
      --tw-translate-y: 0;
      --tw-translate-z: 0;
      --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-border-style: solid;
      --tw-gradient-position: initial;
      --tw-gradient-from: #0000;
      --tw-gradient-via: #0000;
      --tw-gradient-to: #0000;
      --tw-gradient-stops: initial;
      --tw-gradient-via-stops: initial;
      --tw-gradient-from-position: 0%;
      --tw-gradient-via-position: 50%;
      --tw-gradient-to-position: 100%;
      --tw-leading: initial;
      --tw-font-weight: 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-outline-style: solid;
      --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-ease: initial;
      --tw-animation-delay: 0s;
      --tw-animation-direction: normal;
      --tw-animation-duration: initial;
      --tw-animation-fill-mode: none;
      --tw-animation-iteration-count: 1;
      --tw-enter-blur: 0;
      --tw-enter-opacity: 1;
      --tw-enter-rotate: 0;
      --tw-enter-scale: 1;
      --tw-enter-translate-x: 0;
      --tw-enter-translate-y: 0;
      --tw-exit-blur: 0;
      --tw-exit-opacity: 1;
      --tw-exit-rotate: 0;
      --tw-exit-scale: 1;
      --tw-exit-translate-x: 0;
      --tw-exit-translate-y: 0;
      --scroll-fade-t: 0px;
      --scroll-fade-b: 0px;
      --scroll-fade-s: 0px;
      --scroll-fade-e: 0px;
      --scroll-fade-mask: initial;
      --shimmer-image: initial;
      --shimmer-text-fill: initial;
    }
  }
}

@layer theme {
  :root, :host {
    --font-sans: var(--font-sans);
    --color-red-200: #ffcaca;
    --color-red-500: #fb2c36;
    --color-blue-400: #54a2ff;
    --color-blue-500: #3080ff;
    --color-blue-600: #155dfc;
    --color-slate-100: #f1f5f9;
    --color-slate-300: #cad5e2;
    --color-slate-900: #0f172b;
    --color-slate-950: #020618;
    --color-zinc-50: #fafafa;
    --color-zinc-300: #d4d4d8;
    --color-zinc-400: #9f9fa9;
    --color-zinc-500: #71717b;
    --color-zinc-900: #18181b;
    --color-zinc-950: #09090b;
    --color-black: #000;
    --color-white: #fff;
    --spacing: .25rem;
    --container-xs: 20rem;
    --container-sm: 24rem;
    --text-xs: .75rem;
    --text-xs--line-height: calc(1 / .75);
    --text-sm: .875rem;
    --text-sm--line-height: calc(1.25 / .875);
    --text-base: 1rem;
    --text-base--line-height: calc(1.5 / 1);
    --text-xl: 1.25rem;
    --text-xl--line-height: calc(1.75 / 1.25);
    --text-6xl: 3.75rem;
    --text-6xl--line-height: 1;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --leading-relaxed: 1.625;
    --radius-md: calc(var(--radius) * .8);
    --ease-in-out: cubic-bezier(.4, 0, .2, 1);
    --animate-spin: spin 1s linear infinite;
    --blur-sm: 8px;
    --default-transition-duration: .15s;
    --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    --default-font-family: var(--font-sans);
    --default-mono-font-family: var(--font-geist-mono);
    --color-border: var(--border);
  }

  @supports (color: lab(0% 0 0)) {
    :root, :host {
      --color-red-200: lab(86.017% 19.8815 7.75869);
      --color-red-500: lab(55.4814% 75.0732 48.8528);
      --color-blue-400: lab(65.0361% -1.42065 -56.9802);
      --color-blue-500: lab(54.1736% 13.3369 -74.6839);
      --color-blue-600: lab(44.0605% 29.0279 -86.0352);
      --color-slate-100: lab(96.286% -.852436 -2.46847);
      --color-slate-300: lab(84.7652% -1.94535 -7.93337);
      --color-slate-900: lab(7.78673% 1.82345 -15.0537);
      --color-slate-950: lab(1.76974% 1.32743 -9.28855);
      --color-zinc-50: lab(98.26% 0 0);
      --color-zinc-300: lab(84.9837% .601262 -2.17986);
      --color-zinc-400: lab(65.6464% 1.53497 -5.42429);
      --color-zinc-500: lab(47.8878% 1.65477 -5.77283);
      --color-zinc-900: lab(8.30603% .618205 -2.16572);
      --color-zinc-950: lab(2.51107% .242703 -.886115);
    }
  }
}

@layer base {
  *, :after, :before, ::backdrop {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0;
  }

  ::file-selector-button {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0;
  }

  html, :host {
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    line-height: 1.5;
    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;
    -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 {
    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;
  }

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

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

  button, input, select, optgroup, textarea {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: #0000;
    border-radius: 0;
  }

  ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: #0000;
    border-radius: 0;
  }

  :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)) {
      ::placeholder {
        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 {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-year-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-month-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-day-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-hour-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-minute-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-second-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-millisecond-field {
    padding-block: 0;
  }

  ::-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"]) {
    appearance: button;
  }

  ::file-selector-button {
    appearance: button;
  }

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

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

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

  * {
    border-color: var(--border);
    outline-color: var(--ring);
  }

  @supports (color: color-mix(in lab, red, red)) {
    * {
      outline-color: color-mix(in oklab, var(--ring) 50%, transparent);
    }
  }

  body {
    background-color: var(--background);
    color: var(--foreground);
  }

  html {
    font-family: var(--font-sans);
  }
}

@layer components {
  .canvas-app-shell {
    background-color: var(--muted);
    width: 100vw;
    height: 100vh;
    display: flex;
    position: relative;
    overflow: hidden;
  }

  .gallery-panel {
    z-index: 20;
    border-right-style: var(--tw-border-style);
    background-color: var(--background);
    border-right-width: 1px;
    flex-direction: column;
    flex-shrink: 0;
    display: flex;
    position: relative;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .gallery-panel {
      background-color: color-mix(in oklab, var(--background) 95%, transparent);
    }
  }

  .gallery-panel {
    padding: calc(var(--spacing) * 4);
    --tw-shadow: 0 20px 25px -5px var(--tw-shadow-color, #0000001a), 0 8px 10px -6px var(--tw-shadow-color, #0000001a);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    --tw-backdrop-blur: blur(8px);
    -webkit-backdrop-filter: var(--tw-backdrop-blur, ) var(--tw-backdrop-brightness, ) var(--tw-backdrop-contrast, ) var(--tw-backdrop-grayscale, ) var(--tw-backdrop-hue-rotate, ) var(--tw-backdrop-invert, ) var(--tw-backdrop-opacity, ) var(--tw-backdrop-saturate, ) var(--tw-backdrop-sepia, );
    backdrop-filter: var(--tw-backdrop-blur, ) var(--tw-backdrop-brightness, ) var(--tw-backdrop-contrast, ) var(--tw-backdrop-grayscale, ) var(--tw-backdrop-hue-rotate, ) var(--tw-backdrop-invert, ) var(--tw-backdrop-opacity, ) var(--tw-backdrop-saturate, ) var(--tw-backdrop-sepia, );
  }

  .gallery-panel:is(.dark *) {
    border-color: #ffffff1a;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .gallery-panel:is(.dark *) {
      border-color: color-mix(in oklab, var(--color-white) 10%, transparent);
    }
  }

  .gallery-panel:is(.dark *) {
    background-color: #09090bf2;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .gallery-panel:is(.dark *) {
      background-color: color-mix(in oklab, var(--color-zinc-950) 95%, transparent);
    }
  }

  .gallery-panel:is(.dark *) {
    color: var(--color-zinc-50);
  }

  .gallery-resize-handle {
    z-index: 30;
    height: 100%;
    width: var(--spacing);
    cursor: col-resize;
    position: absolute;
    top: 0;
    right: 0;
  }

  @media (hover: hover) {
    .gallery-resize-handle:hover {
      background-color: var(--primary);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .gallery-resize-handle:hover {
        background-color: color-mix(in oklab, var(--primary) 20%, transparent);
      }
    }
  }

  .canvas-surface {
    flex: 1;
    position: relative;
  }

  .canvas-toolbar {
    --tw-translate-x: calc(calc(1 / 2 * 100%) * -1);
    width: max-content;
    max-width: calc(100% - 2rem);
    translate: var(--tw-translate-x) var(--tw-translate-y);
    align-items: center;
    gap: calc(var(--spacing) * 3);
    border-radius: calc(var(--radius) * 1.8);
    border-style: var(--tw-border-style);
    background-color: var(--background);
    border-width: 1px;
    display: flex;
    position: absolute;
    left: 50%;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .canvas-toolbar {
      background-color: color-mix(in oklab, var(--background) 95%, transparent);
    }
  }

  .canvas-toolbar {
    padding-inline: calc(var(--spacing) * 3);
    padding-block: calc(var(--spacing) * 2);
    --tw-shadow: 0 20px 25px -5px var(--tw-shadow-color, #0000001a), 0 8px 10px -6px var(--tw-shadow-color, #0000001a);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    --tw-backdrop-blur: blur(8px);
    -webkit-backdrop-filter: var(--tw-backdrop-blur, ) var(--tw-backdrop-brightness, ) var(--tw-backdrop-contrast, ) var(--tw-backdrop-grayscale, ) var(--tw-backdrop-hue-rotate, ) var(--tw-backdrop-invert, ) var(--tw-backdrop-opacity, ) var(--tw-backdrop-saturate, ) var(--tw-backdrop-sepia, );
    backdrop-filter: var(--tw-backdrop-blur, ) var(--tw-backdrop-brightness, ) var(--tw-backdrop-contrast, ) var(--tw-backdrop-grayscale, ) var(--tw-backdrop-hue-rotate, ) var(--tw-backdrop-invert, ) var(--tw-backdrop-opacity, ) var(--tw-backdrop-saturate, ) var(--tw-backdrop-sepia, );
    z-index: 2147483647;
  }

  .generation-panel {
    right: calc(var(--spacing) * 4);
    z-index: 20;
    border-radius: calc(var(--radius) * 2.2);
    border-style: var(--tw-border-style);
    background-color: var(--background);
    border-width: 1px;
    width: 340px;
    position: absolute;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .generation-panel {
      background-color: color-mix(in oklab, var(--background) 95%, transparent);
    }
  }

  .generation-panel {
    padding: calc(var(--spacing) * 4);
    --tw-shadow: 0 25px 50px -12px var(--tw-shadow-color, #00000040);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    --tw-backdrop-blur: blur(8px);
    -webkit-backdrop-filter: var(--tw-backdrop-blur, ) var(--tw-backdrop-brightness, ) var(--tw-backdrop-contrast, ) var(--tw-backdrop-grayscale, ) var(--tw-backdrop-hue-rotate, ) var(--tw-backdrop-invert, ) var(--tw-backdrop-opacity, ) var(--tw-backdrop-saturate, ) var(--tw-backdrop-sepia, );
    backdrop-filter: var(--tw-backdrop-blur, ) var(--tw-backdrop-brightness, ) var(--tw-backdrop-contrast, ) var(--tw-backdrop-grayscale, ) var(--tw-backdrop-hue-rotate, ) var(--tw-backdrop-invert, ) var(--tw-backdrop-opacity, ) var(--tw-backdrop-saturate, ) var(--tw-backdrop-sepia, );
    top: 50%;
    transform: translateY(-50%);
  }
}

@layer utilities {
  .pointer-events-none {
    pointer-events: none;
  }

  .invisible {
    visibility: hidden;
  }

  .visible {
    visibility: visible;
  }

  .absolute {
    position: absolute;
  }

  .fixed {
    position: fixed;
  }

  .relative {
    position: relative;
  }

  .inset-0 {
    inset: 0;
  }

  .inset-x-0 {
    inset-inline: 0;
  }

  .top-0\.5 {
    top: calc(var(--spacing) * .5);
  }

  .top-1\/2 {
    top: 50%;
  }

  .top-3 {
    top: calc(var(--spacing) * 3);
  }

  .top-full {
    top: 100%;
  }

  .right-0 {
    right: 0;
  }

  .right-0\.5 {
    right: calc(var(--spacing) * .5);
  }

  .right-3 {
    right: calc(var(--spacing) * 3);
  }

  .bottom-0 {
    bottom: 0;
  }

  .bottom-3 {
    bottom: calc(var(--spacing) * 3);
  }

  .left-0 {
    left: 0;
  }

  .isolate {
    isolation: isolate;
  }

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

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

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

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

  .container {
    width: 100%;
  }

  @media (min-width: 40rem) {
    .container {
      max-width: 40rem;
    }
  }

  @media (min-width: 48rem) {
    .container {
      max-width: 48rem;
    }
  }

  @media (min-width: 64rem) {
    .container {
      max-width: 64rem;
    }
  }

  @media (min-width: 80rem) {
    .container {
      max-width: 80rem;
    }
  }

  @media (min-width: 96rem) {
    .container {
      max-width: 96rem;
    }
  }

  .mx-2 {
    margin-inline: calc(var(--spacing) * 2);
  }

  .my-5 {
    margin-block: calc(var(--spacing) * 5);
  }

  .mt-1 {
    margin-top: var(--spacing);
  }

  .mt-2 {
    margin-top: calc(var(--spacing) * 2);
  }

  .mt-3 {
    margin-top: calc(var(--spacing) * 3);
  }

  .mt-5 {
    margin-top: calc(var(--spacing) * 5);
  }

  .mt-6 {
    margin-top: calc(var(--spacing) * 6);
  }

  .mb-1 {
    margin-bottom: var(--spacing);
  }

  .mb-2 {
    margin-bottom: calc(var(--spacing) * 2);
  }

  .mb-3 {
    margin-bottom: calc(var(--spacing) * 3);
  }

  .mb-4 {
    margin-bottom: calc(var(--spacing) * 4);
  }

  .mb-5 {
    margin-bottom: calc(var(--spacing) * 5);
  }

  .ml-0\.5 {
    margin-left: calc(var(--spacing) * .5);
  }

  .block {
    display: block;
  }

  .flex {
    display: flex;
  }

  .grid {
    display: grid;
  }

  .hidden {
    display: none;
  }

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

  .field-sizing-content {
    field-sizing: content;
  }

  .size-2\.5 {
    width: calc(var(--spacing) * 2.5);
    height: calc(var(--spacing) * 2.5);
  }

  .size-3 {
    width: calc(var(--spacing) * 3);
    height: calc(var(--spacing) * 3);
  }

  .size-3\.5 {
    width: calc(var(--spacing) * 3.5);
    height: calc(var(--spacing) * 3.5);
  }

  .size-4 {
    width: calc(var(--spacing) * 4);
    height: calc(var(--spacing) * 4);
  }

  .size-5 {
    width: calc(var(--spacing) * 5);
    height: calc(var(--spacing) * 5);
  }

  .size-6 {
    width: calc(var(--spacing) * 6);
    height: calc(var(--spacing) * 6);
  }

  .size-7 {
    width: calc(var(--spacing) * 7);
    height: calc(var(--spacing) * 7);
  }

  .size-8 {
    width: calc(var(--spacing) * 8);
    height: calc(var(--spacing) * 8);
  }

  .size-9 {
    width: calc(var(--spacing) * 9);
    height: calc(var(--spacing) * 9);
  }

  .size-10 {
    width: calc(var(--spacing) * 10);
    height: calc(var(--spacing) * 10);
  }

  .size-14 {
    width: calc(var(--spacing) * 14);
    height: calc(var(--spacing) * 14);
  }

  .size-full {
    width: 100%;
    height: 100%;
  }

  .h-5 {
    height: calc(var(--spacing) * 5);
  }

  .h-6 {
    height: calc(var(--spacing) * 6);
  }

  .h-7 {
    height: calc(var(--spacing) * 7);
  }

  .h-8 {
    height: calc(var(--spacing) * 8);
  }

  .h-9 {
    height: calc(var(--spacing) * 9);
  }

  .h-20 {
    height: calc(var(--spacing) * 20);
  }

  .h-auto {
    height: auto;
  }

  .h-full {
    height: 100%;
  }

  .max-h-\[80vh\] {
    max-height: 80vh;
  }

  .min-h-16 {
    min-height: calc(var(--spacing) * 16);
  }

  .min-h-24 {
    min-height: calc(var(--spacing) * 24);
  }

  .min-h-full {
    min-height: 100%;
  }

  .min-h-screen {
    min-height: 100vh;
  }

  .w-28 {
    width: calc(var(--spacing) * 28);
  }

  .w-64 {
    width: calc(var(--spacing) * 64);
  }

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

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

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

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

  .w-fit {
    width: fit-content;
  }

  .w-full {
    width: 100%;
  }

  .w-px {
    width: 1px;
  }

  .max-w-sm {
    max-width: var(--container-sm);
  }

  .max-w-xs {
    max-width: var(--container-xs);
  }

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

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

  .flex-1 {
    flex: 1;
  }

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

  .origin-\(--transform-origin\) {
    transform-origin: var(--transform-origin);
  }

  .-translate-y-1\/2 {
    --tw-translate-y: calc(calc(1 / 2 * 100%) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .translate-y-\[calc\(-50\%-2px\)\] {
    --tw-translate-y: calc(-50% - 2px);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .rotate-45 {
    rotate: 45deg;
  }

  .transform {
    transform: var(--tw-rotate-x, ) var(--tw-rotate-y, ) var(--tw-rotate-z, ) var(--tw-skew-x, ) var(--tw-skew-y, );
  }

  .animate-spin {
    animation: var(--animate-spin);
  }

  .cursor-pointer {
    cursor: pointer;
  }

  .touch-none {
    touch-action: none;
  }

  .resize {
    resize: both;
  }

  .resize-none {
    resize: none;
  }

  .flex-col {
    flex-direction: column;
  }

  .flex-wrap {
    flex-wrap: wrap;
  }

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

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

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

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

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

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

  .gap-0\.5 {
    gap: calc(var(--spacing) * .5);
  }

  .gap-1 {
    gap: var(--spacing);
  }

  .gap-1\.5 {
    gap: calc(var(--spacing) * 1.5);
  }

  .gap-2 {
    gap: calc(var(--spacing) * 2);
  }

  .gap-3 {
    gap: calc(var(--spacing) * 3);
  }

  .gap-4 {
    gap: calc(var(--spacing) * 4);
  }

  :where(.space-y-1 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(var(--spacing) * var(--tw-space-y-reverse));
    margin-block-end: calc(var(--spacing) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-2 > :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)));
  }

  :where(.space-y-3 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)));
  }

  .gap-y-3 {
    row-gap: calc(var(--spacing) * 3);
  }

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

  .overflow-hidden {
    overflow: hidden;
  }

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

  .rounded-2xl {
    border-radius: calc(var(--radius) * 1.8);
  }

  .rounded-4xl {
    border-radius: calc(var(--radius) * 2.6);
  }

  .rounded-\[2px\] {
    border-radius: 2px;
  }

  .rounded-\[inherit\] {
    border-radius: inherit;
  }

  .rounded-\[min\(var\(--radius-md\)\,10px\)\] {
    border-radius: min(var(--radius-md), 10px);
  }

  .rounded-\[min\(var\(--radius-md\)\,12px\)\] {
    border-radius: min(var(--radius-md), 12px);
  }

  .rounded-full {
    border-radius: 3.40282e38px;
  }

  .rounded-lg {
    border-radius: var(--radius);
  }

  .rounded-md {
    border-radius: calc(var(--radius) * .8);
  }

  .rounded-sm {
    border-radius: calc(var(--radius) * .6);
  }

  .rounded-xl {
    border-radius: calc(var(--radius) * 1.4);
  }

  .rounded-r-xl {
    border-top-right-radius: calc(var(--radius) * 1.4);
    border-bottom-right-radius: calc(var(--radius) * 1.4);
  }

  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }

  .border-l-0 {
    border-left-style: var(--tw-border-style);
    border-left-width: 0;
  }

  .border-border {
    border-color: var(--border);
  }

  .border-input {
    border-color: var(--input);
  }

  .border-primary {
    border-color: var(--primary);
  }

  .border-transparent {
    border-color: #0000;
  }

  .border-white\/10 {
    border-color: #ffffff1a;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-white\/10 {
      border-color: color-mix(in oklab, var(--color-white) 10%, transparent);
    }
  }

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

  .bg-background\/90 {
    background-color: var(--background);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-background\/90 {
      background-color: color-mix(in oklab, var(--background) 90%, transparent);
    }
  }

  .bg-background\/95 {
    background-color: var(--background);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-background\/95 {
      background-color: color-mix(in oklab, var(--background) 95%, transparent);
    }
  }

  .bg-black\/40 {
    background-color: #0006;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-black\/40 {
      background-color: color-mix(in oklab, var(--color-black) 40%, transparent);
    }
  }

  .bg-black\/50 {
    background-color: #00000080;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-black\/50 {
      background-color: color-mix(in oklab, var(--color-black) 50%, transparent);
    }
  }

  .bg-blue-500 {
    background-color: var(--color-blue-500);
  }

  .bg-border {
    background-color: var(--border);
  }

  .bg-destructive\/10 {
    background-color: var(--destructive);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-destructive\/10 {
      background-color: color-mix(in oklab, var(--destructive) 10%, transparent);
    }
  }

  .bg-foreground {
    background-color: var(--foreground);
  }

  .bg-muted {
    background-color: var(--muted);
  }

  .bg-muted\/30 {
    background-color: var(--muted);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-muted\/30 {
      background-color: color-mix(in oklab, var(--muted) 30%, transparent);
    }
  }

  .bg-muted\/45 {
    background-color: var(--muted);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-muted\/45 {
      background-color: color-mix(in oklab, var(--muted) 45%, transparent);
    }
  }

  .bg-muted\/50 {
    background-color: var(--muted);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-muted\/50 {
      background-color: color-mix(in oklab, var(--muted) 50%, transparent);
    }
  }

  .bg-primary {
    background-color: var(--primary);
  }

  .bg-primary\/10 {
    background-color: var(--primary);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-primary\/10 {
      background-color: color-mix(in oklab, var(--primary) 10%, transparent);
    }
  }

  .bg-red-500\/15 {
    background-color: #fb2c3626;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-red-500\/15 {
      background-color: color-mix(in oklab, var(--color-red-500) 15%, transparent);
    }
  }

  .bg-secondary {
    background-color: var(--secondary);
  }

  .bg-slate-900\/80 {
    background-color: #0f172bcc;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-slate-900\/80 {
      background-color: color-mix(in oklab, var(--color-slate-900) 80%, transparent);
    }
  }

  .bg-slate-950 {
    background-color: var(--color-slate-950);
  }

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

  .bg-zinc-950\/95 {
    background-color: #09090bf2;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-zinc-950\/95 {
      background-color: color-mix(in oklab, var(--color-zinc-950) 95%, transparent);
    }
  }

  .bg-gradient-to-t {
    --tw-gradient-position: to top in oklab;
    background-image: linear-gradient(var(--tw-gradient-stops));
  }

  .from-black\/70 {
    --tw-gradient-from: #000000b3;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .from-black\/70 {
      --tw-gradient-from: color-mix(in oklab, var(--color-black) 70%, transparent);
    }
  }

  .from-black\/70 {
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }

  .to-transparent {
    --tw-gradient-to: transparent;
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }

  .bg-clip-padding {
    background-clip: padding-box;
  }

  .fill-foreground {
    fill: var(--foreground);
  }

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

  .object-cover {
    object-fit: cover;
  }

  .p-1 {
    padding: var(--spacing);
  }

  .p-1\.5 {
    padding: calc(var(--spacing) * 1.5);
  }

  .p-2 {
    padding: calc(var(--spacing) * 2);
  }

  .p-3 {
    padding: calc(var(--spacing) * 3);
  }

  .p-4 {
    padding: calc(var(--spacing) * 4);
  }

  .p-6 {
    padding: calc(var(--spacing) * 6);
  }

  .p-px {
    padding: 1px;
  }

  .px-1 {
    padding-inline: var(--spacing);
  }

  .px-2 {
    padding-inline: calc(var(--spacing) * 2);
  }

  .px-2\.5 {
    padding-inline: calc(var(--spacing) * 2.5);
  }

  .px-3 {
    padding-inline: calc(var(--spacing) * 3);
  }

  .px-4 {
    padding-inline: calc(var(--spacing) * 4);
  }

  .px-6 {
    padding-inline: calc(var(--spacing) * 6);
  }

  .py-0\.5 {
    padding-block: calc(var(--spacing) * .5);
  }

  .py-1 {
    padding-block: var(--spacing);
  }

  .py-1\.5 {
    padding-block: calc(var(--spacing) * 1.5);
  }

  .py-2 {
    padding-block: calc(var(--spacing) * 2);
  }

  .py-4 {
    padding-block: calc(var(--spacing) * 4);
  }

  .py-8 {
    padding-block: calc(var(--spacing) * 8);
  }

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

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

  .text-6xl {
    font-size: var(--text-6xl);
    line-height: var(--tw-leading, var(--text-6xl--line-height));
  }

  .text-base {
    font-size: var(--text-base);
    line-height: var(--tw-leading, var(--text-base--line-height));
  }

  .text-sm {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
  }

  .text-xl {
    font-size: var(--text-xl);
    line-height: var(--tw-leading, var(--text-xl--line-height));
  }

  .text-xs {
    font-size: var(--text-xs);
    line-height: var(--tw-leading, var(--text-xs--line-height));
  }

  .text-\[0\.8rem\] {
    font-size: .8rem;
  }

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

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

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

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

  .leading-relaxed {
    --tw-leading: var(--leading-relaxed);
    line-height: var(--leading-relaxed);
  }

  .font-bold {
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
  }

  .font-medium {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }

  .font-semibold {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }

  .whitespace-nowrap {
    white-space: nowrap;
  }

  .text-background {
    color: var(--background);
  }

  .text-blue-500 {
    color: var(--color-blue-500);
  }

  .text-destructive {
    color: var(--destructive);
  }

  .text-foreground {
    color: var(--foreground);
  }

  .text-muted-foreground {
    color: var(--muted-foreground);
  }

  .text-muted-foreground\/40 {
    color: var(--muted-foreground);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-muted-foreground\/40 {
      color: color-mix(in oklab, var(--muted-foreground) 40%, transparent);
    }
  }

  .text-primary {
    color: var(--primary);
  }

  .text-primary-foreground {
    color: var(--primary-foreground);
  }

  .text-red-200 {
    color: var(--color-red-200);
  }

  .text-secondary-foreground {
    color: var(--secondary-foreground);
  }

  .text-slate-100 {
    color: var(--color-slate-100);
  }

  .text-slate-300 {
    color: var(--color-slate-300);
  }

  .text-white {
    color: var(--color-white);
  }

  .text-white\/90 {
    color: #ffffffe6;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-white\/90 {
      color: color-mix(in oklab, var(--color-white) 90%, transparent);
    }
  }

  .uppercase {
    text-transform: uppercase;
  }

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

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

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

  .antialiased {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }

  .opacity-0 {
    opacity: 0;
  }

  .shadow {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, #0000001a), 0 1px 2px -1px var(--tw-shadow-color, #0000001a);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .shadow-2xl {
    --tw-shadow: 0 25px 50px -12px var(--tw-shadow-color, #00000040);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .shadow-md {
    --tw-shadow: 0 4px 6px -1px var(--tw-shadow-color, #0000001a), 0 2px 4px -2px var(--tw-shadow-color, #0000001a);
    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, #0000001a), 0 1px 2px -1px var(--tw-shadow-color, #0000001a);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .shadow-xl {
    --tw-shadow: 0 20px 25px -5px var(--tw-shadow-color, #0000001a), 0 8px 10px -6px var(--tw-shadow-color, #0000001a);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .outline {
    outline-style: var(--tw-outline-style);
    outline-width: 1px;
  }

  .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 {
    --tw-backdrop-blur: blur(8px);
    -webkit-backdrop-filter: var(--tw-backdrop-blur, ) var(--tw-backdrop-brightness, ) var(--tw-backdrop-contrast, ) var(--tw-backdrop-grayscale, ) var(--tw-backdrop-hue-rotate, ) var(--tw-backdrop-invert, ) var(--tw-backdrop-opacity, ) var(--tw-backdrop-saturate, ) var(--tw-backdrop-sepia, );
    backdrop-filter: var(--tw-backdrop-blur, ) var(--tw-backdrop-brightness, ) var(--tw-backdrop-contrast, ) var(--tw-backdrop-grayscale, ) var(--tw-backdrop-hue-rotate, ) var(--tw-backdrop-invert, ) var(--tw-backdrop-opacity, ) var(--tw-backdrop-saturate, ) var(--tw-backdrop-sepia, );
  }

  .backdrop-blur-sm {
    --tw-backdrop-blur: blur(var(--blur-sm));
    -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-\[color\,box-shadow\] {
    transition-property: color, box-shadow;
    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));
  }

  .transition-opacity {
    transition-property: opacity;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .ease-in-out {
    --tw-ease: var(--ease-in-out);
    transition-timing-function: var(--ease-in-out);
  }

  .outline-none {
    --tw-outline-style: none;
    outline-style: none;
  }

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

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

  @media (hover: hover) {
    .group-hover\:flex:is(:where(.group):hover *) {
      display: flex;
    }
  }

  @media (hover: hover) {
    .group-hover\:opacity-100:is(:where(.group):hover *) {
      opacity: 1;
    }
  }

  .group-data-\[disabled\=true\]\:pointer-events-none:is(:where(.group)[data-disabled="true"] *) {
    pointer-events: none;
  }

  .group-data-\[disabled\=true\]\:opacity-50:is(:where(.group)[data-disabled="true"] *) {
    opacity: .5;
  }

  .peer-disabled\:cursor-not-allowed:is(:where(.peer):disabled ~ *) {
    cursor: not-allowed;
  }

  .peer-disabled\:opacity-50:is(:where(.peer):disabled ~ *) {
    opacity: .5;
  }

  .file\:inline-flex::file-selector-button {
    display: inline-flex;
  }

  .file\:h-6::file-selector-button {
    height: calc(var(--spacing) * 6);
  }

  .file\:border-0::file-selector-button {
    border-style: var(--tw-border-style);
    border-width: 0;
  }

  .file\:bg-transparent::file-selector-button {
    background-color: #0000;
  }

  .file\:text-sm::file-selector-button {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
  }

  .file\:font-medium::file-selector-button {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }

  .file\:text-foreground::file-selector-button {
    color: var(--foreground);
  }

  .placeholder\:text-muted-foreground::placeholder {
    color: var(--muted-foreground);
  }

  @media (hover: hover) {
    .hover\:border-primary\/50:hover {
      border-color: var(--primary);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:border-primary\/50:hover {
        border-color: color-mix(in oklab, var(--primary) 50%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-\[color-mix\(in_oklch\,var\(--secondary\)\,var\(--foreground\)_5\%\)\]:hover {
      background-color: var(--secondary);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:bg-\[color-mix\(in_oklch\,var\(--secondary\)\,var\(--foreground\)_5\%\)\]:hover {
        background-color: color-mix(in oklch,var(--secondary),var(--foreground) 5%);
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-accent:hover {
      background-color: var(--accent);
    }
  }

  @media (hover: hover) {
    .hover\:bg-blue-400:hover {
      background-color: var(--color-blue-400);
    }
  }

  @media (hover: hover) {
    .hover\:bg-destructive:hover {
      background-color: var(--destructive);
    }
  }

  @media (hover: hover) {
    .hover\:bg-destructive\/20:hover {
      background-color: var(--destructive);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:bg-destructive\/20:hover {
        background-color: color-mix(in oklab, var(--destructive) 20%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-muted:hover {
      background-color: var(--muted);
    }
  }

  @media (hover: hover) {
    .hover\:bg-primary\/80:hover {
      background-color: var(--primary);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:bg-primary\/80:hover {
        background-color: color-mix(in oklab, var(--primary) 80%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-primary\/90:hover {
      background-color: var(--primary);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:bg-primary\/90:hover {
        background-color: color-mix(in oklab, var(--primary) 90%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:text-blue-600:hover {
      color: var(--color-blue-600);
    }
  }

  @media (hover: hover) {
    .hover\:text-foreground:hover {
      color: var(--foreground);
    }
  }

  @media (hover: hover) {
    .hover\:text-muted-foreground:hover {
      color: var(--muted-foreground);
    }
  }

  @media (hover: hover) {
    .hover\:underline:hover {
      text-decoration-line: underline;
    }
  }

  @media (hover: hover) {
    .hover\:shadow-md:hover {
      --tw-shadow: 0 4px 6px -1px var(--tw-shadow-color, #0000001a), 0 2px 4px -2px var(--tw-shadow-color, #0000001a);
      box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }
  }

  .focus\:border-blue-400:focus {
    border-color: var(--color-blue-400);
  }

  .focus\:ring-2:focus {
    --tw-ring-shadow: var(--tw-ring-inset, ) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .focus\:ring-primary\/30:focus {
    --tw-ring-color: var(--primary);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .focus\:ring-primary\/30:focus {
      --tw-ring-color: color-mix(in oklab, var(--primary) 30%, transparent);
    }
  }

  .focus\:outline-none:focus {
    --tw-outline-style: none;
    outline-style: none;
  }

  .focus-visible\:border-destructive\/40:focus-visible {
    border-color: var(--destructive);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .focus-visible\:border-destructive\/40:focus-visible {
      border-color: color-mix(in oklab, var(--destructive) 40%, transparent);
    }
  }

  .focus-visible\:border-ring:focus-visible {
    border-color: var(--ring);
  }

  .focus-visible\:ring-3:focus-visible {
    --tw-ring-shadow: var(--tw-ring-inset, ) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .focus-visible\:ring-\[3px\]:focus-visible {
    --tw-ring-shadow: var(--tw-ring-inset, ) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .focus-visible\:ring-destructive\/20:focus-visible {
    --tw-ring-color: var(--destructive);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .focus-visible\:ring-destructive\/20:focus-visible {
      --tw-ring-color: color-mix(in oklab, var(--destructive) 20%, transparent);
    }
  }

  .focus-visible\:ring-ring\/50:focus-visible {
    --tw-ring-color: var(--ring);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .focus-visible\:ring-ring\/50:focus-visible {
      --tw-ring-color: color-mix(in oklab, var(--ring) 50%, transparent);
    }
  }

  .focus-visible\:outline-1:focus-visible {
    outline-style: var(--tw-outline-style);
    outline-width: 1px;
  }

  .active\:not-aria-\[haspopup\]\:translate-y-px:active:not([aria-haspopup]) {
    --tw-translate-y: 1px;
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .disabled\:pointer-events-none:disabled {
    pointer-events: none;
  }

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

  .disabled\:bg-input\/50:disabled {
    background-color: var(--input);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .disabled\:bg-input\/50:disabled {
      background-color: color-mix(in oklab, var(--input) 50%, transparent);
    }
  }

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

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

  :where([data-slot="button-group"]) .in-data-\[slot\=button-group\]\:rounded-lg {
    border-radius: var(--radius);
  }

  .has-data-\[icon\=inline-end\]\:pr-1\.5:has([data-icon="inline-end"]) {
    padding-right: calc(var(--spacing) * 1.5);
  }

  .has-data-\[icon\=inline-end\]\:pr-2:has([data-icon="inline-end"]) {
    padding-right: calc(var(--spacing) * 2);
  }

  .has-data-\[icon\=inline-start\]\:pl-1\.5:has([data-icon="inline-start"]) {
    padding-left: calc(var(--spacing) * 1.5);
  }

  .has-data-\[icon\=inline-start\]\:pl-2:has([data-icon="inline-start"]) {
    padding-left: calc(var(--spacing) * 2);
  }

  .has-data-\[slot\=kbd\]\:pr-1\.5:has([data-slot="kbd"]) {
    padding-right: calc(var(--spacing) * 1.5);
  }

  .aria-expanded\:bg-muted[aria-expanded="true"] {
    background-color: var(--muted);
  }

  .aria-expanded\:bg-secondary[aria-expanded="true"] {
    background-color: var(--secondary);
  }

  .aria-expanded\:text-foreground[aria-expanded="true"] {
    color: var(--foreground);
  }

  .aria-expanded\:text-secondary-foreground[aria-expanded="true"] {
    color: var(--secondary-foreground);
  }

  .aria-invalid\:border-destructive[aria-invalid="true"] {
    border-color: var(--destructive);
  }

  .aria-invalid\:ring-3[aria-invalid="true"] {
    --tw-ring-shadow: var(--tw-ring-inset, ) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .aria-invalid\:ring-destructive\/20[aria-invalid="true"] {
    --tw-ring-color: var(--destructive);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .aria-invalid\:ring-destructive\/20[aria-invalid="true"] {
      --tw-ring-color: color-mix(in oklab, var(--destructive) 20%, transparent);
    }
  }

  .data-\[side\=bottom\]\:top-1[data-side="bottom"] {
    top: var(--spacing);
  }

  .data-\[side\=bottom\]\:slide-in-from-top-2[data-side="bottom"] {
    --tw-enter-translate-y: calc(2*var(--spacing)*-1);
  }

  .data-\[side\=inline-end\]\:top-1\/2\![data-side="inline-end"] {
    top: 50% !important;
  }

  .data-\[side\=inline-end\]\:-left-1[data-side="inline-end"] {
    left: calc(var(--spacing) * -1);
  }

  .data-\[side\=inline-end\]\:-translate-y-1\/2[data-side="inline-end"] {
    --tw-translate-y: calc(calc(1 / 2 * 100%) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .data-\[side\=inline-end\]\:slide-in-from-left-2[data-side="inline-end"] {
    --tw-enter-translate-x: calc(2*var(--spacing)*-1);
  }

  .data-\[side\=inline-start\]\:top-1\/2\![data-side="inline-start"] {
    top: 50% !important;
  }

  .data-\[side\=inline-start\]\:-right-1[data-side="inline-start"] {
    right: calc(var(--spacing) * -1);
  }

  .data-\[side\=inline-start\]\:-translate-y-1\/2[data-side="inline-start"] {
    --tw-translate-y: calc(calc(1 / 2 * 100%) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .data-\[side\=inline-start\]\:slide-in-from-right-2[data-side="inline-start"] {
    --tw-enter-translate-x: calc(2*var(--spacing));
  }

  .data-\[side\=left\]\:top-1\/2\![data-side="left"] {
    top: 50% !important;
  }

  .data-\[side\=left\]\:-right-1[data-side="left"] {
    right: calc(var(--spacing) * -1);
  }

  .data-\[side\=left\]\:-translate-y-1\/2[data-side="left"] {
    --tw-translate-y: calc(calc(1 / 2 * 100%) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .data-\[side\=left\]\:slide-in-from-right-2[data-side="left"] {
    --tw-enter-translate-x: calc(2*var(--spacing));
  }

  .data-\[side\=right\]\:top-1\/2\![data-side="right"] {
    top: 50% !important;
  }

  .data-\[side\=right\]\:-left-1[data-side="right"] {
    left: calc(var(--spacing) * -1);
  }

  .data-\[side\=right\]\:-translate-y-1\/2[data-side="right"] {
    --tw-translate-y: calc(calc(1 / 2 * 100%) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .data-\[side\=right\]\:slide-in-from-left-2[data-side="right"] {
    --tw-enter-translate-x: calc(2*var(--spacing)*-1);
  }

  .data-\[side\=top\]\:-bottom-2\.5[data-side="top"] {
    bottom: calc(var(--spacing) * -2.5);
  }

  .data-\[side\=top\]\:slide-in-from-bottom-2[data-side="top"] {
    --tw-enter-translate-y: calc(2*var(--spacing));
  }

  :is(.\*\*\:data-\[slot\=kbd\]\:relative *)[data-slot="kbd"] {
    position: relative;
  }

  :is(.\*\*\:data-\[slot\=kbd\]\:isolate *)[data-slot="kbd"] {
    isolation: isolate;
  }

  :is(.\*\*\:data-\[slot\=kbd\]\:z-50 *)[data-slot="kbd"] {
    z-index: 50;
  }

  :is(.\*\*\:data-\[slot\=kbd\]\:rounded-sm *)[data-slot="kbd"] {
    border-radius: calc(var(--radius) * .6);
  }

  .data-\[state\=delayed-open\]\:animate-in[data-state="delayed-open"] {
    animation: enter var(--tw-animation-duration, var(--tw-duration, .15s))var(--tw-ease, ease)var(--tw-animation-delay, 0s)var(--tw-animation-iteration-count, 1)var(--tw-animation-direction, normal)var(--tw-animation-fill-mode, none);
  }

  .data-\[state\=delayed-open\]\:fade-in-0[data-state="delayed-open"] {
    --tw-enter-opacity: 0;
  }

  .data-\[state\=delayed-open\]\:zoom-in-95[data-state="delayed-open"] {
    --tw-enter-scale: .95;
  }

  @media (min-width: 48rem) {
    .md\:text-sm {
      font-size: var(--text-sm);
      line-height: var(--tw-leading, var(--text-sm--line-height));
    }
  }

  @media (min-width: 64rem) {
    .lg\:block {
      display: block;
    }
  }

  .dark\:border-input:is(.dark *) {
    border-color: var(--input);
  }

  .dark\:border-white\/10:is(.dark *) {
    border-color: #ffffff1a;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .dark\:border-white\/10:is(.dark *) {
      border-color: color-mix(in oklab, var(--color-white) 10%, transparent);
    }
  }

  .dark\:bg-destructive\/20:is(.dark *) {
    background-color: var(--destructive);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .dark\:bg-destructive\/20:is(.dark *) {
      background-color: color-mix(in oklab, var(--destructive) 20%, transparent);
    }
  }

  .dark\:bg-input\/30:is(.dark *) {
    background-color: var(--input);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .dark\:bg-input\/30:is(.dark *) {
      background-color: color-mix(in oklab, var(--input) 30%, transparent);
    }
  }

  .dark\:bg-zinc-900:is(.dark *) {
    background-color: var(--color-zinc-900);
  }

  .dark\:bg-zinc-950:is(.dark *) {
    background-color: var(--color-zinc-950);
  }

  .dark\:text-white:is(.dark *) {
    color: var(--color-white);
  }

  .dark\:text-zinc-300:is(.dark *) {
    color: var(--color-zinc-300);
  }

  .dark\:text-zinc-400:is(.dark *) {
    color: var(--color-zinc-400);
  }

  .dark\:placeholder\:text-zinc-500:is(.dark *)::placeholder {
    color: var(--color-zinc-500);
  }

  @media (hover: hover) {
    .dark\:hover\:bg-destructive\/30:is(.dark *):hover {
      background-color: var(--destructive);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .dark\:hover\:bg-destructive\/30:is(.dark *):hover {
        background-color: color-mix(in oklab, var(--destructive) 30%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .dark\:hover\:bg-input\/50:is(.dark *):hover {
      background-color: var(--input);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .dark\:hover\:bg-input\/50:is(.dark *):hover {
        background-color: color-mix(in oklab, var(--input) 50%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .dark\:hover\:bg-muted\/50:is(.dark *):hover {
      background-color: var(--muted);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .dark\:hover\:bg-muted\/50:is(.dark *):hover {
        background-color: color-mix(in oklab, var(--muted) 50%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .dark\:hover\:bg-white\/10:is(.dark *):hover {
      background-color: #ffffff1a;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .dark\:hover\:bg-white\/10:is(.dark *):hover {
        background-color: color-mix(in oklab, var(--color-white) 10%, transparent);
      }
    }
  }

  .dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible {
    --tw-ring-color: var(--destructive);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible {
      --tw-ring-color: color-mix(in oklab, var(--destructive) 40%, transparent);
    }
  }

  .dark\:disabled\:bg-input\/80:is(.dark *):disabled {
    background-color: var(--input);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .dark\:disabled\:bg-input\/80:is(.dark *):disabled {
      background-color: color-mix(in oklab, var(--input) 80%, transparent);
    }
  }

  .dark\:aria-invalid\:border-destructive\/50:is(.dark *)[aria-invalid="true"] {
    border-color: var(--destructive);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .dark\:aria-invalid\:border-destructive\/50:is(.dark *)[aria-invalid="true"] {
      border-color: color-mix(in oklab, var(--destructive) 50%, transparent);
    }
  }

  .dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid="true"] {
    --tw-ring-color: var(--destructive);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid="true"] {
      --tw-ring-color: color-mix(in oklab, var(--destructive) 40%, transparent);
    }
  }

  .data-open\:animate-in:where([data-state="open"]), .data-open\:animate-in:where([data-open]:not([data-open="false"])) {
    animation: enter var(--tw-animation-duration, var(--tw-duration, .15s))var(--tw-ease, ease)var(--tw-animation-delay, 0s)var(--tw-animation-iteration-count, 1)var(--tw-animation-direction, normal)var(--tw-animation-fill-mode, none);
  }

  .data-open\:fade-in-0:where([data-state="open"]), .data-open\:fade-in-0:where([data-open]:not([data-open="false"])) {
    --tw-enter-opacity: 0;
  }

  .data-open\:zoom-in-95:where([data-state="open"]), .data-open\:zoom-in-95:where([data-open]:not([data-open="false"])) {
    --tw-enter-scale: .95;
  }

  .data-closed\:animate-out:where([data-state="closed"]), .data-closed\:animate-out:where([data-closed]:not([data-closed="false"])) {
    animation: exit var(--tw-animation-duration, var(--tw-duration, .15s))var(--tw-ease, ease)var(--tw-animation-delay, 0s)var(--tw-animation-iteration-count, 1)var(--tw-animation-direction, normal)var(--tw-animation-fill-mode, none);
  }

  .data-closed\:fade-out-0:where([data-state="closed"]), .data-closed\:fade-out-0:where([data-closed]:not([data-closed="false"])) {
    --tw-exit-opacity: 0;
  }

  .data-closed\:zoom-out-95:where([data-state="closed"]), .data-closed\:zoom-out-95:where([data-closed]:not([data-closed="false"])) {
    --tw-exit-scale: .95;
  }

  .data-horizontal\:h-2\.5:where([data-orientation="horizontal"]) {
    height: calc(var(--spacing) * 2.5);
  }

  .data-horizontal\:h-px:where([data-orientation="horizontal"]) {
    height: 1px;
  }

  .data-horizontal\:w-full:where([data-orientation="horizontal"]) {
    width: 100%;
  }

  .data-horizontal\:flex-col:where([data-orientation="horizontal"]) {
    flex-direction: column;
  }

  .data-horizontal\:border-t:where([data-orientation="horizontal"]) {
    border-top-style: var(--tw-border-style);
    border-top-width: 1px;
  }

  .data-horizontal\:border-t-transparent:where([data-orientation="horizontal"]) {
    border-top-color: #0000;
  }

  .data-vertical\:h-full:where([data-orientation="vertical"]) {
    height: 100%;
  }

  .data-vertical\:w-2\.5:where([data-orientation="vertical"]) {
    width: calc(var(--spacing) * 2.5);
  }

  .data-vertical\:w-px:where([data-orientation="vertical"]) {
    width: 1px;
  }

  .data-vertical\:self-stretch:where([data-orientation="vertical"]) {
    align-self: stretch;
  }

  .data-vertical\:border-l:where([data-orientation="vertical"]) {
    border-left-style: var(--tw-border-style);
    border-left-width: 1px;
  }

  .data-vertical\:border-l-transparent:where([data-orientation="vertical"]) {
    border-left-color: #0000;
  }

  .\[\&_svg\]\:pointer-events-none svg {
    pointer-events: none;
  }

  .\[\&_svg\]\:shrink-0 svg {
    flex-shrink: 0;
  }

  .\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-3 svg:not([class*="size-"]) {
    width: calc(var(--spacing) * 3);
    height: calc(var(--spacing) * 3);
  }

  .\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-3\.5 svg:not([class*="size-"]) {
    width: calc(var(--spacing) * 3.5);
    height: calc(var(--spacing) * 3.5);
  }

  .\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-4 svg:not([class*="size-"]) {
    width: calc(var(--spacing) * 4);
    height: calc(var(--spacing) * 4);
  }

  @media (hover: hover) {
    .\[a\]\:hover\:bg-destructive\/20:is(a):hover {
      background-color: var(--destructive);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .\[a\]\:hover\:bg-destructive\/20:is(a):hover {
        background-color: color-mix(in oklab, var(--destructive) 20%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .\[a\]\:hover\:bg-muted:is(a):hover {
      background-color: var(--muted);
    }
  }

  @media (hover: hover) {
    .\[a\]\:hover\:bg-primary\/80:is(a):hover {
      background-color: var(--primary);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .\[a\]\:hover\:bg-primary\/80:is(a):hover {
        background-color: color-mix(in oklab, var(--primary) 80%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .\[a\]\:hover\:bg-secondary\/80:is(a):hover {
      background-color: var(--secondary);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .\[a\]\:hover\:bg-secondary\/80:is(a):hover {
        background-color: color-mix(in oklab, var(--secondary) 80%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .\[a\]\:hover\:text-muted-foreground:is(a):hover {
      color: var(--muted-foreground);
    }
  }

  .\[\&\>svg\]\:pointer-events-none > svg {
    pointer-events: none;
  }

  .\[\&\>svg\]\:size-3\! > svg {
    width: calc(var(--spacing) * 3) !important;
    height: calc(var(--spacing) * 3) !important;
  }
}

@property --tw-animation-delay {
  syntax: "*";
  inherits: false;
  initial-value: 0s;
}

@property --tw-animation-direction {
  syntax: "*";
  inherits: false;
  initial-value: normal;
}

@property --tw-animation-duration {
  syntax: "*";
  inherits: false
}

@property --tw-animation-fill-mode {
  syntax: "*";
  inherits: false;
  initial-value: none;
}

@property --tw-animation-iteration-count {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}

@property --tw-enter-blur {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-enter-opacity {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}

@property --tw-enter-rotate {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-enter-scale {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}

@property --tw-enter-translate-x {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-enter-translate-y {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-exit-blur {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-exit-opacity {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}

@property --tw-exit-rotate {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-exit-scale {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}

@property --tw-exit-translate-x {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-exit-translate-y {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --scroll-fade-t {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 0;
}

@property --scroll-fade-b {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 0;
}

@property --scroll-fade-s {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 0;
}

@property --scroll-fade-e {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 0;
}

@property --scroll-fade-mask {
  syntax: "*";
  inherits: false
}

@property --shimmer-angle {
  syntax: "<angle>";
  inherits: true;
  initial-value: 20deg;
}

@property --shimmer-image {
  syntax: "*";
  inherits: false
}

@property --shimmer-text-fill {
  syntax: "*";
  inherits: false
}

@media (prefers-reduced-motion: reduce) {
  .shimmer {
    -webkit-text-fill-color: currentColor;
    background-image: none;
    animation: none;
  }
}

@font-face {
  font-family: tldraw_draw;
  src: local(HongLei), local(HongLei Regular), local(鸿雷板书简体（免费可商用）);
  unicode-range: U+3000-303F, U+3400-4DBF, U+4E00-9FFF, U+F900-FAFF, U+FF00-FFEF;
}

:root {
  --background: #fff;
  --foreground: #0a0a0a;
  --card: #fff;
  --card-foreground: #0a0a0a;
  --popover: #fff;
  --popover-foreground: #0a0a0a;
  --primary: #171717;
  --primary-foreground: #fafafa;
  --secondary: #f5f5f5;
  --secondary-foreground: #171717;
  --muted: #f5f5f5;
  --muted-foreground: #737373;
  --accent: #f5f5f5;
  --accent-foreground: #171717;
  --destructive: #e40014;
  --border: #e5e5e5;
  --input: #e5e5e5;
  --ring: #a1a1a1;
  --chart-1: #d4d4d4;
  --chart-2: #737373;
  --chart-3: #525252;
  --chart-4: #404040;
  --chart-5: #262626;
  --radius: .625rem;
  --sidebar: #fafafa;
  --sidebar-foreground: #0a0a0a;
  --sidebar-primary: #171717;
  --sidebar-primary-foreground: #fafafa;
  --sidebar-accent: #f5f5f5;
  --sidebar-accent-foreground: #171717;
  --sidebar-border: #e5e5e5;
  --sidebar-ring: #a1a1a1;
}

@supports (color: lab(0% 0 0)) {
  :root {
    --background: lab(100% 0 0);
    --foreground: lab(2.75381% 0 0);
    --card: lab(100% 0 0);
    --card-foreground: lab(2.75381% 0 0);
    --popover: lab(100% 0 0);
    --popover-foreground: lab(2.75381% 0 0);
    --primary: lab(7.78201% -.0000149012 0);
    --primary-foreground: lab(98.26% 0 0);
    --secondary: lab(96.52% -.0000298023 .0000119209);
    --secondary-foreground: lab(7.78201% -.0000149012 0);
    --muted: lab(96.52% -.0000298023 .0000119209);
    --muted-foreground: lab(48.496% 0 0);
    --accent: lab(96.52% -.0000298023 .0000119209);
    --accent-foreground: lab(7.78201% -.0000149012 0);
    --destructive: lab(48.4493% 77.4328 61.5452);
    --border: lab(90.952% 0 -.0000119209);
    --input: lab(90.952% 0 -.0000119209);
    --ring: lab(66.128% -.0000298023 .0000119209);
    --chart-1: lab(84.92% 0 -.0000119209);
    --chart-2: lab(48.496% 0 0);
    --chart-3: lab(34.924% 0 0);
    --chart-4: lab(27.036% 0 0);
    --chart-5: lab(15.204% 0 -.00000596046);
    --sidebar: lab(98.26% 0 0);
    --sidebar-foreground: lab(2.75381% 0 0);
    --sidebar-primary: lab(7.78201% -.0000149012 0);
    --sidebar-primary-foreground: lab(98.26% 0 0);
    --sidebar-accent: lab(96.52% -.0000298023 .0000119209);
    --sidebar-accent-foreground: lab(7.78201% -.0000149012 0);
    --sidebar-border: lab(90.952% 0 -.0000119209);
    --sidebar-ring: lab(66.128% -.0000298023 .0000119209);
  }
}

.dark {
  --background: #0a0a0a;
  --foreground: #fafafa;
  --card: #171717;
  --card-foreground: #fafafa;
  --popover: #171717;
  --popover-foreground: #fafafa;
  --primary: #e5e5e5;
  --primary-foreground: #171717;
  --secondary: #262626;
  --secondary-foreground: #fafafa;
  --muted: #262626;
  --muted-foreground: #a1a1a1;
  --accent: #262626;
  --accent-foreground: #fafafa;
  --destructive: #ff6568;
  --border: #ffffff1a;
  --input: #ffffff26;
  --ring: #737373;
  --chart-1: #d4d4d4;
  --chart-2: #737373;
  --chart-3: #525252;
  --chart-4: #404040;
  --chart-5: #262626;
  --sidebar: #171717;
  --sidebar-foreground: #fafafa;
  --sidebar-primary: #1447e6;
  --sidebar-primary-foreground: #fafafa;
  --sidebar-accent: #262626;
  --sidebar-accent-foreground: #fafafa;
  --sidebar-border: #ffffff1a;
  --sidebar-ring: #737373;
}

@supports (color: lab(0% 0 0)) {
  .dark {
    --background: lab(2.75381% 0 0);
    --foreground: lab(98.26% 0 0);
    --card: lab(7.78201% -.0000149012 0);
    --card-foreground: lab(98.26% 0 0);
    --popover: lab(7.78201% -.0000149012 0);
    --popover-foreground: lab(98.26% 0 0);
    --primary: lab(90.952% 0 -.0000119209);
    --primary-foreground: lab(7.78201% -.0000149012 0);
    --secondary: lab(15.204% 0 -.00000596046);
    --secondary-foreground: lab(98.26% 0 0);
    --muted: lab(15.204% 0 -.00000596046);
    --muted-foreground: lab(66.128% -.0000298023 .0000119209);
    --accent: lab(15.204% 0 -.00000596046);
    --accent-foreground: lab(98.26% 0 0);
    --destructive: lab(63.7053% 60.745 31.3109);
    --border: lab(100% 0 0 / .1);
    --input: lab(100% 0 0 / .15);
    --ring: lab(48.496% 0 0);
    --chart-1: lab(84.92% 0 -.0000119209);
    --chart-2: lab(48.496% 0 0);
    --chart-3: lab(34.924% 0 0);
    --chart-4: lab(27.036% 0 0);
    --chart-5: lab(15.204% 0 -.00000596046);
    --sidebar: lab(7.78201% -.0000149012 0);
    --sidebar-foreground: lab(98.26% 0 0);
    --sidebar-primary: lab(36.9089% 35.0961 -85.6872);
    --sidebar-primary-foreground: lab(98.26% 0 0);
    --sidebar-accent: lab(15.204% 0 -.00000596046);
    --sidebar-accent-foreground: lab(98.26% 0 0);
    --sidebar-border: lab(100% 0 0 / .1);
    --sidebar-ring: lab(48.496% 0 0);
  }
}

.rainbow-text {
  background: linear-gradient(90deg, red, #f70, #ff0, #0f0, #00f, #8b00ff, red) 0 0 / 200%;
  -webkit-text-fill-color: transparent;
  -webkit-background-clip: text;
  background-clip: text;
  animation: 3s linear infinite rainbow-shift;
}

@keyframes rainbow-shift {
  0% {
    background-position: 0%;
  }

  100% {
    background-position: 200%;
  }
}

.canvas-app-shell[data-dialog-open] .tlui-layout__top__left, .canvas-app-shell[data-dialog-open] .tlui-layout__bottom__left, .canvas-app-shell[data-dialog-open] .tlui-layout__bottom__center, .canvas-app-shell[data-dialog-open] .tlui-layout__bottom__right, .canvas-app-shell[data-dialog-open] .tlui-toolbar, .canvas-app-shell[data-dialog-open] .tlui-menu, .canvas-app-shell[data-dialog-open] .tlui-popover, .canvas-app-shell[data-dialog-open] .canvas-toolbar, .canvas-app-shell[data-dialog-open] .generation-panel {
  opacity: .15;
  pointer-events: none;
  transition: opacity .2s;
}

.canvas-app-shell[data-dialog-open] .tlui-layout__bottom, .canvas-app-shell[data-dialog-open] .tlui-layout__top__left, .canvas-app-shell[data-dialog-open] .tlui-menu, .canvas-app-shell[data-dialog-open] .tlui-popover, .canvas-app-shell[data-dialog-open] .tlui-menu-zone, .canvas-app-shell[data-dialog-open] .tlui-menu-click-capture, .canvas-app-shell[data-dialog-open] .tlui-minimap, .canvas-app-shell[data-dialog-open] .tlui-zoom-menu__button {
  visibility: hidden;
  pointer-events: none;
}

body.gallery-dialog-open .tlui-layout__top__left, body.gallery-dialog-open .tlui-layout__bottom, body.gallery-dialog-open .tlui-menu, body.gallery-dialog-open .tlui-popover, body.gallery-dialog-open .tlui-menu-zone, body.gallery-dialog-open .tlui-menu-click-capture, body.gallery-dialog-open .tlui-minimap, body.gallery-dialog-open .tlui-zoom-menu__button, body.gallery-dialog-open .tlui-contextual-toolbar, body.gallery-dialog-open .tlui-toolbar, body.records-dialog-open .tlui-layout__top__left, body.records-dialog-open .tlui-layout__bottom, body.records-dialog-open .tlui-menu, body.records-dialog-open .tlui-popover, body.records-dialog-open .tlui-menu-zone, body.records-dialog-open .tlui-menu-click-capture, body.records-dialog-open .tlui-minimap, body.records-dialog-open .tlui-zoom-menu__button, body.records-dialog-open .tlui-contextual-toolbar, body.records-dialog-open .tlui-toolbar {
  visibility: hidden !important;
  pointer-events: none !important;
}

.canvas-app-shell[data-dialog-open] .tl-watermark_SEE-LICENSE, .tl-watermark_SEE-LICENSE {
  display: none !important;
}

[data-radix-menu-content] {
  max-height: calc(100vh - 16px);
  overflow-y: auto;
}

.image-lightbox-overlay {
  z-index: 2147483647;
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  touch-action: none;
  -webkit-user-select: none;
  user-select: none;
  background: #000000d9;
  justify-content: center;
  align-items: center;
  display: flex;
  position: fixed;
  inset: 0;
}

.image-lightbox-close {
  z-index: 2147483647;
  color: #fff;
  cursor: pointer;
  background: #ffffff26;
  border: none;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  transition: background .15s;
  display: flex;
  position: fixed;
  top: 16px;
  right: 16px;
}

.image-lightbox-close:hover {
  background: #ffffff4d;
}

.image-lightbox-img {
  object-fit: contain;
  will-change: transform;
  transform-origin: center;
  pointer-events: auto;
}

.image-editor-overlay {
  flex-direction: column;
  gap: 16px;
  padding: 72px 24px 24px;
}

.image-editor-toolbar {
  z-index: 2147483647;
  color: #fff;
  background: #121212db;
  border: 1px solid #ffffff2e;
  border-radius: 999px;
  align-items: center;
  gap: 8px;
  padding: 8px;
  display: flex;
  position: fixed;
  top: 16px;
  left: 50%;
  transform: translateX(-50%);
  box-shadow: 0 16px 48px #00000059;
}

.image-editor-toolbar button {
  color: #fff;
  white-space: nowrap;
  cursor: pointer;
  background: #ffffff1f;
  border: 0;
  border-radius: 999px;
  align-items: center;
  gap: 6px;
  height: 34px;
  padding: 0 12px;
  font-size: 13px;
  display: inline-flex;
}

.image-editor-toolbar button:hover, .image-editor-toolbar button.active {
  background: #ffffff42;
}

.image-editor-toolbar button.primary {
  color: #06250f;
  background: #22c55e;
  font-weight: 700;
}

.image-editor-toolbar button:disabled {
  cursor: not-allowed;
  opacity: .55;
}

.image-editor-hint {
  color: #ffffffb8;
  white-space: nowrap;
  padding: 0 8px;
  font-size: 12px;
}

.image-editor-separator {
  background: #fff3;
  flex-shrink: 0;
  width: 1px;
  height: 20px;
}

.image-editor-width {
  cursor: pointer;
  align-items: center;
  gap: 6px;
  display: inline-flex;
}

.image-editor-width-label {
  color: #ffffffd9;
  text-align: center;
  -webkit-user-select: none;
  user-select: none;
  min-width: 30px;
  font-size: 12px;
}

.image-editor-width input[type="range"] {
  appearance: none;
  background: #ffffff40;
  border-radius: 2px;
  outline: none;
  width: 80px;
  height: 4px;
}

.image-editor-width input[type="range"]::-webkit-slider-thumb {
  appearance: none;
  cursor: pointer;
  background: #fff;
  border-radius: 50%;
  width: 14px;
  height: 14px;
  box-shadow: 0 1px 4px #0000004d;
}

.image-editor-width input[type="range"]::-moz-range-thumb {
  cursor: pointer;
  background: #fff;
  border: none;
  border-radius: 50%;
  width: 14px;
  height: 14px;
  box-shadow: 0 1px 4px #0000004d;
}

.image-editor-canvas {
  object-fit: contain;
  cursor: crosshair;
  touch-action: none;
  background: #111;
  border-radius: 10px;
  max-width: calc(100vw - 48px);
  max-height: calc(100vh - 120px);
  box-shadow: 0 24px 80px #00000073;
}

.tlui-contextual-toolbar, .canvas-surface .tlui-contextual-toolbar {
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.asui-image-toolbar {
  background: var(--color-panel, #fdfdfd);
  border: 1px solid var(--color-border, #00000014);
  border-radius: 8px;
  align-items: center;
  gap: 2px;
  padding: 4px;
  display: flex;
  box-shadow: 0 2px 8px #0000001a;
}

.asui-image-toolbar-btn {
  width: 32px;
  height: 32px;
  color: var(--color-text-1, #1d1d1f);
  cursor: pointer;
  background: none;
  border: 0;
  border-radius: 6px;
  justify-content: center;
  align-items: center;
  transition: background .1s;
  display: inline-flex;
}

.asui-image-toolbar-btn:hover {
  background: var(--color-muted-2, #0000000f);
}

.asui-image-toolbar-btn:active {
  background: var(--color-muted-3, #0000001a);
}

@media (max-width: 860px) {
  .canvas-toolbar {
    --tw-translate-x: calc(calc(1 / 2 * 100%) * -1);
    width: calc(100vw - 1.5rem);
    translate: var(--tw-translate-x) var(--tw-translate-y);
    flex-wrap: wrap;
    justify-content: center;
    left: 50%;
    right: auto;
  }

  .generation-panel {
    top: auto;
    right: calc(var(--spacing) * 3);
    bottom: calc(var(--spacing) * 3);
    left: calc(var(--spacing) * 3);
    border-radius: calc(var(--radius) * 1.8);
    width: auto;
    max-height: 46vh;
    overflow-y: auto;
  }

  .gallery-panel {
    display: none;
  }
}

@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-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-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}

@property --tw-gradient-position {
  syntax: "*";
  inherits: false
}

@property --tw-gradient-from {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}

@property --tw-gradient-via {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}

@property --tw-gradient-to {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}

@property --tw-gradient-stops {
  syntax: "*";
  inherits: false
}

@property --tw-gradient-via-stops {
  syntax: "*";
  inherits: false
}

@property --tw-gradient-from-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 0%;
}

@property --tw-gradient-via-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 50%;
}

@property --tw-gradient-to-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 100%;
}

@property --tw-leading {
  syntax: "*";
  inherits: false
}

@property --tw-font-weight {
  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: 0;
}

@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-outline-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}

@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-ease {
  syntax: "*";
  inherits: false
}

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

@keyframes enter {
  from {
    opacity: var(--tw-enter-opacity, 1);
    transform: translate3d(var(--tw-enter-translate-x, 0),var(--tw-enter-translate-y, 0),0)scale3d(var(--tw-enter-scale, 1),var(--tw-enter-scale, 1),var(--tw-enter-scale, 1))rotate(var(--tw-enter-rotate, 0));
    filter: blur(var(--tw-enter-blur, 0));
  }
}

@keyframes exit {
  to {
    opacity: var(--tw-exit-opacity, 1);
    transform: translate3d(var(--tw-exit-translate-x, 0),var(--tw-exit-translate-y, 0),0)scale3d(var(--tw-exit-scale, 1),var(--tw-exit-scale, 1),var(--tw-exit-scale, 1))rotate(var(--tw-exit-rotate, 0));
    filter: blur(var(--tw-exit-blur, 0));
  }
}

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