@import url('https://fonts.bunny.net/css?family=inter:400,500,600,700&display=swap');@import url('https://fonts.bunny.net/css?family=jetbrains-mono:400,500&display=swap');

*, ::before, ::after{
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}
::backdrop{
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}
/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/
/*
1. Prevent padding and border from affecting element width. (https://github.com/mozdevs/cssremedy/issues/4)
2. Allow adding a border to an element by just adding a border-width. (https://github.com/tailwindcss/tailwindcss/pull/116)
*/
*,
::before,
::after {
  box-sizing: border-box; /* 1 */
  border-width: 0; /* 2 */
  border-style: solid; /* 2 */
  border-color: #e5e7eb; /* 2 */
}
::before,
::after {
  --tw-content: '';
}
/*
1. Use a consistent sensible line-height in all browsers.
2. Prevent adjustments of font size after orientation changes in iOS.
3. Use a more readable tab size.
4. Use the user's configured `sans` font-family by default.
5. Use the user's configured `sans` font-feature-settings by default.
6. Use the user's configured `sans` font-variation-settings by default.
7. Disable tap highlights on iOS
*/
html,
:host {
  line-height: 1.5; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -moz-tab-size: 4; /* 3 */
  -o-tab-size: 4;
     tab-size: 4; /* 3 */
  font-family: Inter, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; /* 4 */
  font-feature-settings: normal; /* 5 */
  font-variation-settings: normal; /* 6 */
  -webkit-tap-highlight-color: transparent; /* 7 */
}
/*
1. Remove the margin in all browsers.
2. Inherit line-height from `html` so users can set them as a class directly on the `html` element.
*/
body {
  margin: 0; /* 1 */
  line-height: inherit; /* 2 */
}
/*
1. Add the correct height in Firefox.
2. Correct the inheritance of border color in Firefox. (https://bugzilla.mozilla.org/show_bug.cgi?id=190655)
3. Ensure horizontal rules are visible by default.
*/
hr {
  height: 0; /* 1 */
  color: inherit; /* 2 */
  border-top-width: 1px; /* 3 */
}
/*
Add the correct text decoration in Chrome, Edge, and Safari.
*/
abbr:where([title]) {
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}
/*
Remove the default font size and weight for headings.
*/
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
}
/*
Reset links to optimize for opt-in styling instead of opt-out.
*/
a {
  color: inherit;
  text-decoration: inherit;
}
/*
Add the correct font weight in Edge and Safari.
*/
b,
strong {
  font-weight: bolder;
}
/*
1. Use the user's configured `mono` font-family by default.
2. Use the user's configured `mono` font-feature-settings by default.
3. Use the user's configured `mono` font-variation-settings by default.
4. Correct the odd `em` font sizing in all browsers.
*/
code,
kbd,
samp,
pre {
  font-family: JetBrains Mono, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; /* 1 */
  font-feature-settings: normal; /* 2 */
  font-variation-settings: normal; /* 3 */
  font-size: 1em; /* 4 */
}
/*
Add the correct font size in all browsers.
*/
small {
  font-size: 80%;
}
/*
Prevent `sub` and `sup` elements from affecting the line height in all browsers.
*/
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sub {
  bottom: -0.25em;
}
sup {
  top: -0.5em;
}
/*
1. Remove text indentation from table contents in Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=999088, https://bugs.webkit.org/show_bug.cgi?id=201297)
2. Correct table border color inheritance in all Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=935729, https://bugs.webkit.org/show_bug.cgi?id=195016)
3. Remove gaps between table borders by default.
*/
table {
  text-indent: 0; /* 1 */
  border-color: inherit; /* 2 */
  border-collapse: collapse; /* 3 */
}
/*
1. Change the font styles in all browsers.
2. Remove the margin in Firefox and Safari.
3. Remove default padding in all browsers.
*/
button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-feature-settings: inherit; /* 1 */
  font-variation-settings: inherit; /* 1 */
  font-size: 100%; /* 1 */
  font-weight: inherit; /* 1 */
  line-height: inherit; /* 1 */
  letter-spacing: inherit; /* 1 */
  color: inherit; /* 1 */
  margin: 0; /* 2 */
  padding: 0; /* 3 */
}
/*
Remove the inheritance of text transform in Edge and Firefox.
*/
button,
select {
  text-transform: none;
}
/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Remove default button styles.
*/
button,
input:where([type='button']),
input:where([type='reset']),
input:where([type='submit']) {
  -webkit-appearance: button; /* 1 */
  background-color: transparent; /* 2 */
  background-image: none; /* 2 */
}
/*
Use the modern Firefox focus style for all focusable elements.
*/
:-moz-focusring {
  outline: auto;
}
/*
Remove the additional `:invalid` styles in Firefox. (https://github.com/mozilla/gecko-dev/blob/2f9eacd9d3d995c937b4251a5557d95d494c9be1/layout/style/res/forms.css#L728-L737)
*/
:-moz-ui-invalid {
  box-shadow: none;
}
/*
Add the correct vertical alignment in Chrome and Firefox.
*/
progress {
  vertical-align: baseline;
}
/*
Correct the cursor style of increment and decrement buttons in Safari.
*/
::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}
/*
1. Correct the odd appearance in Chrome and Safari.
2. Correct the outline style in Safari.
*/
[type='search'] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}
/*
Remove the inner padding in Chrome and Safari on macOS.
*/
::-webkit-search-decoration {
  -webkit-appearance: none;
}
/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Change font properties to `inherit` in Safari.
*/
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}
/*
Add the correct display in Chrome and Safari.
*/
summary {
  display: list-item;
}
/*
Removes the default spacing and border for appropriate elements.
*/
blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
  margin: 0;
}
fieldset {
  margin: 0;
  padding: 0;
}
legend {
  padding: 0;
}
ol,
ul,
menu {
  list-style: none;
  margin: 0;
  padding: 0;
}
/*
Reset default styling for dialogs.
*/
dialog {
  padding: 0;
}
/*
Prevent resizing textareas horizontally by default.
*/
textarea {
  resize: vertical;
}
/*
1. Reset the default placeholder opacity in Firefox. (https://github.com/tailwindlabs/tailwindcss/issues/3300)
2. Set the default placeholder color to the user's configured gray 400 color.
*/
input::-moz-placeholder, textarea::-moz-placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}
input::placeholder,
textarea::placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}
/*
Set the default cursor for buttons.
*/
button,
[role="button"] {
  cursor: pointer;
}
/*
Make sure disabled buttons don't get the pointer cursor.
*/
:disabled {
  cursor: default;
}
/*
1. Make replaced elements `display: block` by default. (https://github.com/mozdevs/cssremedy/issues/14)
2. Add `vertical-align: middle` to align replaced elements more sensibly by default. (https://github.com/jensimmons/cssremedy/issues/14#issuecomment-634934210)
   This can trigger a poorly considered lint error in some tools but is included by design.
*/
img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
  display: block; /* 1 */
  vertical-align: middle; /* 2 */
}
/*
Constrain images and videos to the parent width and preserve their intrinsic aspect ratio. (https://github.com/mozdevs/cssremedy/issues/14)
*/
img,
video {
  max-width: 100%;
  height: auto;
}
/* Make elements with the HTML hidden attribute stay hidden by default */
[hidden]:where(:not([hidden="until-found"])) {
  display: none;
}
input:where([type='text']),input:where(:not([type])),input:where([type='email']),input:where([type='url']),input:where([type='password']),input:where([type='number']),input:where([type='date']),input:where([type='datetime-local']),input:where([type='month']),input:where([type='search']),input:where([type='tel']),input:where([type='time']),input:where([type='week']),select:where([multiple]),textarea,select{
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background-color: #fff;
  border-color: #6b7280;
  border-width: 1px;
  border-radius: 0px;
  padding-top: 0.5rem;
  padding-right: 0.75rem;
  padding-bottom: 0.5rem;
  padding-left: 0.75rem;
  font-size: 1rem;
  line-height: 1.5rem;
  --tw-shadow: 0 0 #0000;
}
input:where([type='text']):focus, input:where(:not([type])):focus, input:where([type='email']):focus, input:where([type='url']):focus, input:where([type='password']):focus, input:where([type='number']):focus, input:where([type='date']):focus, input:where([type='datetime-local']):focus, input:where([type='month']):focus, input:where([type='search']):focus, input:where([type='tel']):focus, input:where([type='time']):focus, input:where([type='week']):focus, select:where([multiple]):focus, textarea:focus, select:focus{
  outline: 2px solid transparent;
  outline-offset: 2px;
  --tw-ring-inset: var(--tw-empty,/*!*/ /*!*/);
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: #2563eb;
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  border-color: #2563eb;
}
input::-moz-placeholder, textarea::-moz-placeholder{
  color: #6b7280;
  opacity: 1;
}
input::placeholder,textarea::placeholder{
  color: #6b7280;
  opacity: 1;
}
::-webkit-datetime-edit-fields-wrapper{
  padding: 0;
}
::-webkit-date-and-time-value{
  min-height: 1.5em;
  text-align: inherit;
}
::-webkit-datetime-edit{
  display: inline-flex;
}
::-webkit-datetime-edit,::-webkit-datetime-edit-year-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field,::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-meridiem-field{
  padding-top: 0;
  padding-bottom: 0;
}
select{
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
  background-position: right 0.5rem center;
  background-repeat: no-repeat;
  background-size: 1.5em 1.5em;
  padding-right: 2.5rem;
  -webkit-print-color-adjust: exact;
          print-color-adjust: exact;
}
select:where([multiple]),select:where([size]:not([size="1"])){
  background-image: initial;
  background-position: initial;
  background-repeat: unset;
  background-size: initial;
  padding-right: 0.75rem;
  -webkit-print-color-adjust: unset;
          print-color-adjust: unset;
}
input:where([type='checkbox']),input:where([type='radio']){
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  padding: 0;
  -webkit-print-color-adjust: exact;
          print-color-adjust: exact;
  display: inline-block;
  vertical-align: middle;
  background-origin: border-box;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  flex-shrink: 0;
  height: 1rem;
  width: 1rem;
  color: #2563eb;
  background-color: #fff;
  border-color: #6b7280;
  border-width: 1px;
  --tw-shadow: 0 0 #0000;
}
input:where([type='checkbox']){
  border-radius: 0px;
}
input:where([type='radio']){
  border-radius: 100%;
}
input:where([type='checkbox']):focus,input:where([type='radio']):focus{
  outline: 2px solid transparent;
  outline-offset: 2px;
  --tw-ring-inset: var(--tw-empty,/*!*/ /*!*/);
  --tw-ring-offset-width: 2px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: #2563eb;
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
}
input:where([type='checkbox']):checked,input:where([type='radio']):checked{
  border-color: transparent;
  background-color: currentColor;
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
}
input:where([type='checkbox']):checked{
  background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3e%3c/svg%3e");
}
@media (forced-colors: active) {
  input:where([type='checkbox']):checked{
    -webkit-appearance: auto;
       -moz-appearance: auto;
            appearance: auto;
  }
}
input:where([type='radio']):checked{
  background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3ccircle cx='8' cy='8' r='3'/%3e%3c/svg%3e");
}
@media (forced-colors: active) {
  input:where([type='radio']):checked{
    -webkit-appearance: auto;
       -moz-appearance: auto;
            appearance: auto;
  }
}
input:where([type='checkbox']):checked:hover,input:where([type='checkbox']):checked:focus,input:where([type='radio']):checked:hover,input:where([type='radio']):checked:focus{
  border-color: transparent;
  background-color: currentColor;
}
input:where([type='checkbox']):indeterminate{
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3e%3cpath stroke='white' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 8h8'/%3e%3c/svg%3e");
  border-color: transparent;
  background-color: currentColor;
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
}
@media (forced-colors: active) {
  input:where([type='checkbox']):indeterminate{
    -webkit-appearance: auto;
       -moz-appearance: auto;
            appearance: auto;
  }
}
input:where([type='checkbox']):indeterminate:hover,input:where([type='checkbox']):indeterminate:focus{
  border-color: transparent;
  background-color: currentColor;
}
input:where([type='file']){
  background: unset;
  border-color: inherit;
  border-width: 0;
  border-radius: 0;
  padding: 0;
  font-size: unset;
  line-height: inherit;
}
input:where([type='file']):focus{
  outline: 1px solid ButtonText;
  outline: 1px auto -webkit-focus-ring-color;
}
.mono { font-family: var(--font-mono); font-feature-settings: 'zero'; }
.tnum { font-variant-numeric: tabular-nums; }
/* ======== Buttons ======== */
.mm-btn{
  display: inline-flex;
  height: 2.25rem;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  white-space: nowrap;
  border-radius: 0.375rem;
  padding-left: 0.875rem;
  padding-right: 0.875rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
  font-weight: 500;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
        border: 1px solid transparent;
}
.mm-btn-sm{
  height: 1.75rem;
  padding-left: 0.5rem;
  padding-right: 0.5rem;
  font-size: 0.75rem;
  line-height: 1rem;
}
.mm-btn-lg{
  height: 2.75rem;
  padding-left: 1rem;
  padding-right: 1rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
}
.mm-btn-primary {
        background: var(--yellow); color: #1A1A1A;
    }
.mm-btn-primary:hover { background: var(--yellow-hover); }
.mm-btn-secondary {
        background: var(--card); color: var(--text); border-color: var(--border);
    }
.mm-btn-secondary:hover { background: var(--bg-soft); border-color: var(--border-strong); }
.mm-btn-danger {
        background: transparent; color: var(--error); border-color: var(--border);
    }
.mm-btn-danger:hover { background: var(--error-soft); border-color: var(--error); }
.mm-btn-ghost {
        background: transparent; color: var(--text-muted);
    }
.mm-btn-ghost:hover { background: var(--bg-soft); color: var(--text); }
/* ======== Inputs ======== */
.mm-input, .mm-select, .mm-textarea {
        width: 100%;
        background: var(--input-bg);
        color: var(--text);
        border: 1px solid var(--border);
        border-radius: 8px;
        padding: 9px 12px;
        font: 400 13px var(--font-sans);
        transition: border-color .12s, box-shadow .12s;
    }
.mm-input:focus, .mm-select:focus, .mm-textarea:focus {
        outline: none;
        border-color: var(--yellow);
        box-shadow: 0 0 0 3px color-mix(in srgb, var(--yellow) 25%, transparent);
    }
.mm-input::-moz-placeholder { color: var(--text-subtle); }
.mm-input::placeholder { color: var(--text-subtle); }
.mm-input:disabled, .mm-select:disabled, .mm-textarea:disabled {
        background: var(--bg-soft);
        color: var(--text-muted);
        cursor: not-allowed;
    }
.mm-field-label {
        display: block;
        font-size: 12px;
        font-weight: 500;
        color: var(--text-muted);
        margin-bottom: 6px;
    }
/* ======== Cards ======== */
.mm-card {
        background: var(--card);
        border: 1px solid var(--border);
        border-radius: 12px;
    }
.mm-card-hd {
        padding: 14px 18px;
        border-bottom: 1px solid var(--border);
        display: flex;
        align-items: center;
        gap: 10px;
    }
.mm-card-hd h3 { margin: 0; font-size: 14px; font-weight: 600; letter-spacing: -0.01em; }
.mm-card-bd { padding: 18px; }
/* ======== Badges ======== */
.mm-badge {
        display: inline-flex; align-items: center; gap: 5px;
        height: 20px; padding: 0 8px;
        border-radius: 4px;
        font-size: 11px; font-weight: 500;
        border: 1px solid transparent;
        white-space: nowrap;
    }
.mm-badge .dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.mm-badge-success { background: var(--success-soft); color: var(--success); }
.mm-badge-warning { background: var(--warning-soft); color: #B45309; }
.mm-badge-error   { background: var(--error-soft); color: var(--error); }
.mm-badge-info    { background: var(--info-soft); color: var(--info); }
.mm-badge-neutral { background: var(--bg-sunken); color: var(--text-muted); border-color: var(--border); }
.mm-badge-yellow  { background: var(--yellow); color: #1A1A1A; }
[data-theme='dark'] .mm-badge-success { background: rgba(34, 197, 94, 0.15); color: #4ADE80; }
[data-theme='dark'] .mm-badge-warning { background: rgba(245, 158, 11, 0.15); color: #FCD34D; }
[data-theme='dark'] .mm-badge-error   { background: rgba(239, 68, 68, 0.15); color: #FCA5A5; }
[data-theme='dark'] .mm-badge-info    { background: rgba(59, 130, 246, 0.15); color: #93C5FD; }
/* ======== Tables ======== */
.mm-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.mm-table th {
        text-align: left;
        font: 600 11px var(--font-sans);
        text-transform: uppercase;
        letter-spacing: 0.06em;
        color: var(--text-muted);
        padding: 10px 14px;
        border-bottom: 1px solid var(--border);
        background: var(--bg-soft);
    }
.mm-table td {
        padding: 12px 14px;
        border-bottom: 1px solid var(--border);
        color: var(--text);
        vertical-align: middle;
    }
.mm-table tbody tr:hover td { background: var(--row-hover); }
.mm-table tr:last-child td { border-bottom: none; }
/* ======== Shell (desktop-first grid) ======== */
.mm-shell {
        display: grid;
        grid-template-columns: 240px 1fr;
        min-height: 100vh;
        width: 100%;
        transition: grid-template-columns .22s ease;
    }
html[data-sidebar='hidden'] .mm-shell { grid-template-columns: 0 1fr; }
html[data-sidebar='hidden'] .mm-shell .mm-sidebar {
        transform: translateX(-100%);
        border-right-color: transparent;
    }
.mm-main { display: flex; flex-direction: column; min-width: 0; min-height: 100vh; }
.mm-content { padding: 24px 28px; overflow: auto; flex: 1; }
/* ======== Sidebar ======== */
.mm-sidebar {
        background: var(--bg-soft);
        border-right: 1px solid var(--border);
        display: flex;
        flex-direction: column;
        padding: 16px 14px;
        overflow-y: auto;
        width: 240px;
        transition: transform .22s ease, border-right-color .22s ease;
    }
.mm-sidebar-top {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 6px 4px 16px 4px;
    }
.mm-brand {
        display: flex;
        align-items: center;
        gap: 10px;
        color: var(--text);
        text-decoration: none;
    }
.mm-brand-name { font-weight: 700; font-size: 15px; letter-spacing: -0.01em; color: var(--text); }
.mm-brand-sub  { font-size: 11px; color: var(--text-muted); letter-spacing: 0.02em; }
.mm-nav { display: flex; flex-direction: column; flex: 1; }
.mm-sidebar-footer {
        margin-top: auto;
        padding-top: 14px;
        border-top: 1px solid var(--border);
    }
.mm-sidebar-footer > * + * { margin-top: 10px; }
.mm-avatar {
        width: 30px; height: 30px;
        border-radius: 50%;
        background: linear-gradient(135deg, #F2B705, #F97316);
        display: grid; place-items: center;
        color: #111;
        font-weight: 600;
        font-size: 12px;
    }
/* Close button inside sidebar: shown on mobile, and on desktop if collapsible.
       We keep it visible on desktop too so users can close from inside the drawer. */
.mm-sb-soon { margin-left: auto; font-size: 10px; color: var(--text-subtle); background: var(--bg-sunken); padding: 1px 6px; border-radius: 10px; }
.mm-backdrop {
        position: fixed;
        inset: 0;
        background: var(--overlay);
        z-index: 40;
    }
/* On desktop, sidebar is always static — never show backdrop or use fixed positioning */
@media (min-width: 961px) {
        .mm-backdrop { display: none !important; }
    }
.mm-sb-section-label {
        font-size: 10px;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.08em;
        color: var(--text-subtle);
        padding: 16px 10px 6px;
    }
.mm-sb-item {
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 8px 10px;
        margin: 1px 0;
        border-radius: 8px;
        color: var(--text-muted);
        font-size: 13px;
        font-weight: 500;
        position: relative;
        transition: background .12s, color .12s;
    }
.mm-sb-item:hover { background: var(--row-hover); color: var(--text); }
.mm-sb-item.active { background: var(--row-hover); color: var(--text); }
.mm-sb-item.active::before {
        content: '';
        position: absolute;
        left: -14px; top: 8px; bottom: 8px;
        width: 3px;
        background: var(--yellow);
        border-radius: 0 3px 3px 0;
    }
.mm-sb-item.disabled { cursor: not-allowed; opacity: 0.5; }
.mm-sb-item.disabled:hover { background: transparent; color: var(--text-muted); }
/* Divider before bottom-of-sidebar variant sections */
.mm-sb-divider {
        height: 1px;
        background: var(--border);
        margin: 14px 6px 2px;
        opacity: 0.7;
    }
/* Tasks variant — teal accent to separate from core features */
.mm-sb-section-label.mm-sb-variant-tasks {
        color: var(--info, #0EA5E9);
    }
.mm-sb-item.mm-sb-variant-tasks {
        color: var(--info, #0EA5E9);
        background: rgba(14, 165, 233, 0.06);
        border: 1px dashed rgba(14, 165, 233, 0.35);
    }
.mm-sb-item.mm-sb-variant-tasks:hover {
        background: rgba(14, 165, 233, 0.12);
        color: var(--info, #0EA5E9);
        border-color: rgba(14, 165, 233, 0.6);
    }
.mm-sb-item.mm-sb-variant-tasks.active {
        background: rgba(14, 165, 233, 0.16);
        color: var(--info, #0EA5E9);
        border-color: rgba(14, 165, 233, 0.7);
    }
.mm-sb-item.mm-sb-variant-tasks.active::before {
        background: var(--info, #0EA5E9);
    }
/* ======== KPI ======== */
.mm-kpi {
        padding: 16px;
        border-radius: 12px;
        background: var(--card);
        border: 1px solid var(--border);
        display: flex;
        flex-direction: column;
        gap: 6px;
        min-height: 108px;
    }
.mm-kpi-label {
        font-size: 11px;
        color: var(--text-muted);
        text-transform: uppercase;
        letter-spacing: 0.08em;
        font-weight: 600;
    }
.mm-kpi-value {
        font-size: 28px;
        font-weight: 700;
        letter-spacing: -0.02em;
        font-variant-numeric: tabular-nums;
    }
.mm-kpi-foot {
        display: flex; align-items: center; gap: 6px;
        font-size: 11px;
        color: var(--text-muted);
        margin-top: auto;
    }
/* ======== Topbar ======== */
.mm-topbar {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 14px 28px;
        border-bottom: 1px solid var(--border);
        background: var(--bg);
        position: sticky;
        top: 0;
        z-index: 10;
    }
.mm-crumbs { font-size: 12px; color: var(--text-muted); min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.mm-crumbs b { color: var(--text); font-weight: 600; }
.mm-crumbs-root { color: var(--text-muted); }
.mm-crumbs-sep { margin: 0 8px; color: var(--text-subtle); }
.mm-topbar-right { margin-left: auto; display: flex; align-items: center; gap: 8px; }
.mm-topbar-quick { display: inline-flex; }
.mm-topbar-quick.active { color: var(--primary); background: var(--bg-soft); }
/* Sidebar items flagged as desktop_in_topbar live in the topbar on desktop. */
.mm-sb-item.is-desktop-hidden { display: none; }
/* On desktop the hamburger in the topbar collapses the sidebar. On mobile it's
       hidden in favour of the fixed bottom navigation's "Menü" button. */
.mm-hamburger { display: grid; }
/* ======== Mobile bottom navigation ======== */
.mm-bottom-nav { display: none; }
.mm-bottom-nav-item {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 2px;
        padding: 8px 4px;
        color: var(--text-muted);
        text-decoration: none;
        background: transparent;
        border: 0;
        cursor: pointer;
        font: 500 10px var(--font-sans);
        position: relative;
    }
.mm-bottom-nav-item.active {
        color: var(--text);
    }
.mm-bottom-nav-item.active::before {
        content: '';
        position: absolute;
        top: 0;
        width: 26px;
        height: 3px;
        background: var(--yellow);
        border-radius: 0 0 3px 3px;
    }
.mm-bottom-nav-item.active .mm-bottom-nav-label { font-weight: 600; }
.mm-bottom-nav-icon { display: grid; place-items: center; height: 20px; }
.mm-bottom-nav-label { font-size: 10.5px; line-height: 1; }
/* ======== Brand logo component ========
       Two img elements; CSS shows only the one that matches the current theme.
       Use !important to beat any inline display rules from the layout. */
.mm-brand-logo-light { display: block !important; }
.mm-brand-logo-dark  { display: none !important; }
[data-theme='dark'] .mm-brand-logo-light { display: none !important; }
[data-theme='dark'] .mm-brand-logo-dark  { display: block !important; }
.mm-icon-btn {
        width: 34px; height: 34px;
        border-radius: 8px;
        display: grid; place-items: center;
        color: var(--text-muted);
        border: 1px solid var(--border);
        background: var(--bg-soft);
        transition: background .12s, color .12s;
        cursor: pointer;
    }
.mm-icon-btn:hover { color: var(--text); background: var(--card-hover); }
/* ======== Chip ======== */
.mm-chip {
        display: inline-flex; align-items: center; gap: 6px;
        height: 28px; padding: 0 12px; border-radius: 14px;
        background: var(--bg-soft); border: 1px solid var(--border);
        font-size: 12px; font-weight: 500; color: var(--text);
        cursor: pointer;
        white-space: nowrap;
    }
.mm-chip:hover { background: var(--card-hover); }
.mm-chip.active { background: var(--text); color: var(--bg); border-color: var(--text); }
/* ======== kbd ======== */
/* ======== Scrollbars ======== */
.mm-scrollable::-webkit-scrollbar { width: 10px; height: 10px; }
.mm-scrollable::-webkit-scrollbar-track { background: transparent; }
.mm-scrollable::-webkit-scrollbar-thumb { background: var(--border); border-radius: 5px; }
.mm-scrollable::-webkit-scrollbar-thumb:hover { background: var(--border-strong); }
/* Legacy helper class used in some older views, kept for compat */
.visible{
  visibility: visible;
}
.collapse{
  visibility: collapse;
}
.fixed{
  position: fixed;
}
.absolute{
  position: absolute;
}
.relative{
  position: relative;
}
.-bottom-16{
  bottom: -4rem;
}
.-left-16{
  left: -4rem;
}
.-left-20{
  left: -5rem;
}
.top-0{
  top: 0px;
}
.z-0{
  z-index: 0;
}
.\!row-span-1{
  grid-row: span 1 / span 1 !important;
}
.-mx-3{
  margin-left: -0.75rem;
  margin-right: -0.75rem;
}
.-ml-px{
  margin-left: -1px;
}
.ml-3{
  margin-left: 0.75rem;
}
.mt-4{
  margin-top: 1rem;
}
.mt-6{
  margin-top: 1.5rem;
}
.block{
  display: block;
}
.flex{
  display: flex;
}
.inline-flex{
  display: inline-flex;
}
.table{
  display: table;
}
.grid{
  display: grid;
}
.\!hidden{
  display: none !important;
}
.hidden{
  display: none;
}
.aspect-video{
  aspect-ratio: 16 / 9;
}
.size-12{
  width: 3rem;
  height: 3rem;
}
.size-5{
  width: 1.25rem;
  height: 1.25rem;
}
.size-6{
  width: 1.5rem;
  height: 1.5rem;
}
.h-12{
  height: 3rem;
}
.h-40{
  height: 10rem;
}
.h-5{
  height: 1.25rem;
}
.h-full{
  height: 100%;
}
.min-h-screen{
  min-height: 100vh;
}
.w-5{
  width: 1.25rem;
}
.w-\[calc\(100\%_\+_8rem\)\]{
  width: calc(100% + 8rem);
}
.w-auto{
  width: auto;
}
.w-full{
  width: 100%;
}
.max-w-2xl{
  max-width: 42rem;
}
.max-w-\[877px\]{
  max-width: 877px;
}
.flex-1{
  flex: 1 1 0%;
}
.flex-shrink{
  flex-shrink: 1;
}
.shrink-0{
  flex-shrink: 0;
}
.border-collapse{
  border-collapse: collapse;
}
.transform{
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.cursor-default{
  cursor: default;
}
.resize{
  resize: both;
}
.grid-cols-2{
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.\!flex-row{
  flex-direction: row !important;
}
.flex-col{
  flex-direction: column;
}
.items-start{
  align-items: flex-start;
}
.items-center{
  align-items: center;
}
.items-stretch{
  align-items: stretch;
}
.justify-end{
  justify-content: flex-end;
}
.justify-center{
  justify-content: center;
}
.justify-between{
  justify-content: space-between;
}
.justify-items-center{
  justify-items: center;
}
.gap-2{
  gap: 0.5rem;
}
.gap-4{
  gap: 1rem;
}
.gap-6{
  gap: 1.5rem;
}
.self-center{
  align-self: center;
}
.overflow-hidden{
  overflow: hidden;
}
.rounded-\[10px\]{
  border-radius: 10px;
}
.rounded-full{
  border-radius: 9999px;
}
.rounded-lg{
  border-radius: 0.5rem;
}
.rounded-md{
  border-radius: 0.375rem;
}
.rounded-sm{
  border-radius: 0.125rem;
}
.rounded-l-md{
  border-top-left-radius: 0.375rem;
  border-bottom-left-radius: 0.375rem;
}
.rounded-r-md{
  border-top-right-radius: 0.375rem;
  border-bottom-right-radius: 0.375rem;
}
.border{
  border-width: 1px;
}
.border-gray-300{
  --tw-border-opacity: 1;
  border-color: rgb(209 213 219 / var(--tw-border-opacity, 1));
}
.border-gray-600{
  --tw-border-opacity: 1;
  border-color: rgb(75 85 99 / var(--tw-border-opacity, 1));
}
.bg-\[\#FF2D20\]\/10{
  background-color: rgb(255 45 32 / 0.1);
}
.bg-black{
  --tw-bg-opacity: 1;
  background-color: rgb(0 0 0 / var(--tw-bg-opacity, 1));
}
.bg-gray-50{
  --tw-bg-opacity: 1;
  background-color: rgb(249 250 251 / var(--tw-bg-opacity, 1));
}
.bg-gray-800{
  --tw-bg-opacity: 1;
  background-color: rgb(31 41 55 / var(--tw-bg-opacity, 1));
}
.bg-white{
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}
.bg-zinc-900{
  --tw-bg-opacity: 1;
  background-color: rgb(24 24 27 / var(--tw-bg-opacity, 1));
}
.bg-gradient-to-b{
  background-image: linear-gradient(to bottom, var(--tw-gradient-stops));
}
.from-transparent{
  --tw-gradient-from: transparent var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}
.via-white{
  --tw-gradient-to: rgb(255 255 255 / 0)  var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), #fff var(--tw-gradient-via-position), var(--tw-gradient-to);
}
.via-zinc-900{
  --tw-gradient-to: rgb(24 24 27 / 0)  var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), #18181b var(--tw-gradient-via-position), var(--tw-gradient-to);
}
.to-white{
  --tw-gradient-to: #fff var(--tw-gradient-to-position);
}
.to-zinc-900{
  --tw-gradient-to: #18181b var(--tw-gradient-to-position);
}
.stroke-\[\#FF2D20\]{
  stroke: #FF2D20;
}
.object-cover{
  -o-object-fit: cover;
     object-fit: cover;
}
.object-top{
  -o-object-position: top;
     object-position: top;
}
.p-6{
  padding: 1.5rem;
}
.px-2{
  padding-left: 0.5rem;
  padding-right: 0.5rem;
}
.px-3{
  padding-left: 0.75rem;
  padding-right: 0.75rem;
}
.px-4{
  padding-left: 1rem;
  padding-right: 1rem;
}
.px-6{
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}
.py-10{
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
}
.py-16{
  padding-top: 4rem;
  padding-bottom: 4rem;
}
.py-2{
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}
.pt-3{
  padding-top: 0.75rem;
}
.text-center{
  text-align: center;
}
.font-sans{
  font-family: Inter, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
}
.text-sm{
  font-size: 0.875rem;
  line-height: 1.25rem;
}
.text-sm\/relaxed{
  font-size: 0.875rem;
  line-height: 1.625;
}
.text-xl{
  font-size: 1.25rem;
  line-height: 1.75rem;
}
.font-medium{
  font-weight: 500;
}
.font-semibold{
  font-weight: 600;
}
.uppercase{
  text-transform: uppercase;
}
.leading-5{
  line-height: 1.25rem;
}
.text-black{
  --tw-text-opacity: 1;
  color: rgb(0 0 0 / var(--tw-text-opacity, 1));
}
.text-black\/50{
  color: rgb(0 0 0 / 0.5);
}
.text-gray-300{
  --tw-text-opacity: 1;
  color: rgb(209 213 219 / var(--tw-text-opacity, 1));
}
.text-gray-400{
  --tw-text-opacity: 1;
  color: rgb(156 163 175 / var(--tw-text-opacity, 1));
}
.text-gray-500{
  --tw-text-opacity: 1;
  color: rgb(107 114 128 / var(--tw-text-opacity, 1));
}
.text-gray-600{
  --tw-text-opacity: 1;
  color: rgb(75 85 99 / var(--tw-text-opacity, 1));
}
.text-gray-700{
  --tw-text-opacity: 1;
  color: rgb(55 65 81 / var(--tw-text-opacity, 1));
}
.text-white{
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}
.underline{
  text-decoration-line: underline;
}
.line-through{
  text-decoration-line: line-through;
}
.antialiased{
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.opacity-0{
  opacity: 0;
}
.opacity-100{
  opacity: 1;
}
.shadow-\[0px_14px_34px_0px_rgba\(0\2c 0\2c 0\2c 0\.08\)\]{
  --tw-shadow: 0px 14px 34px 0px rgba(0,0,0,0.08);
  --tw-shadow-colored: 0px 14px 34px 0px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.shadow-sm{
  --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.outline{
  outline-style: solid;
}
.ring{
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}
.ring-1{
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}
.ring-black{
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(0 0 0 / var(--tw-ring-opacity, 1));
}
.ring-gray-300{
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(209 213 219 / var(--tw-ring-opacity, 1));
}
.ring-transparent{
  --tw-ring-color: transparent;
}
.ring-white{
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(255 255 255 / var(--tw-ring-opacity, 1));
}
.ring-white\/\[0\.05\]{
  --tw-ring-color: rgb(255 255 255 / 0.05);
}
.ring-zinc-800{
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(39 39 42 / var(--tw-ring-opacity, 1));
}
.drop-shadow{
  --tw-drop-shadow: drop-shadow(0 1px 2px rgb(0 0 0 / 0.1)) drop-shadow(0 1px 1px rgb(0 0 0 / 0.06));
  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);
}
.drop-shadow-\[0px_4px_34px_rgba\(0\2c 0\2c 0\2c 0\.06\)\]{
  --tw-drop-shadow: drop-shadow(0px 4px 34px rgba(0,0,0,0.06));
  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);
}
.drop-shadow-\[0px_4px_34px_rgba\(0\2c 0\2c 0\2c 0\.25\)\]{
  --tw-drop-shadow: drop-shadow(0px 4px 34px rgba(0,0,0,0.25));
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}
.filter{
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}
.transition{
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}
.duration-100{
  transition-duration: 100ms;
}
.duration-150{
  transition-duration: 150ms;
}
.duration-300{
  transition-duration: 300ms;
}
.ease-in{
  transition-timing-function: cubic-bezier(0.4, 0, 1, 1);
}
.ease-in-out{
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}
.ease-out{
  transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
}
/* ============================================================
   Design tokens — UP2 Shop admin design system
   (adapted from claude.ai/design bundle)
   ============================================================ */
:root {
    --yellow: #F2B705;
    --yellow-hover: #D9A404;
    --yellow-soft: #FFF4CC;

    --success: #16A34A;
    --success-soft: #DCFCE7;
    --warning: #F59E0B;
    --warning-soft: #FEF3C7;
    --error: #EF4444;
    --error-soft: #FEE2E2;
    --info: #3B82F6;
    --info-soft: #DBEAFE;

    --font-sans: 'Inter', ui-sans-serif, system-ui, -apple-system, sans-serif;
    --font-mono: 'JetBrains Mono', ui-monospace, monospace;
}
/* Light theme (default) */
:root,
[data-theme='light'] {
    --bg: #FFFFFF;
    --bg-soft: #F7F7F8;
    --bg-sunken: #F1F1F3;
    --card: #FFFFFF;
    --card-hover: #FAFAFA;
    --border: #E5E7EB;
    --border-strong: #D1D5DB;
    --text: #0F1115;
    --text-muted: #6B7280;
    --text-subtle: #9CA3AF;
    --overlay: rgba(15, 17, 21, 0.5);
    --shadow-sm: 0 1px 2px rgba(15, 17, 21, 0.04);
    --shadow-md: 0 4px 12px rgba(15, 17, 21, 0.06), 0 1px 2px rgba(15, 17, 21, 0.04);
    --shadow-lg: 0 12px 32px rgba(15, 17, 21, 0.10), 0 2px 4px rgba(15, 17, 21, 0.04);
    --input-bg: #FFFFFF;
    --table-row-alt: #FAFAFA;
    --code-bg: #F4F4F5;
    --chip-bg: #F0F0F0;
    --row-hover: #FAFAFA;
}
[data-theme='dark'] {
    --bg: #0B0B0D;
    --bg-soft: #121214;
    --bg-sunken: #0A0A0C;
    --card: #161618;
    --card-hover: #1C1C1F;
    --border: #26262A;
    --border-strong: #3A3A40;
    --text: #F4F4F5;
    --text-muted: #A1A1AA;
    --text-subtle: #71717A;
    --overlay: rgba(0, 0, 0, 0.6);
    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
    --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.4);
    --shadow-lg: 0 12px 32px rgba(0, 0, 0, 0.5);
    --input-bg: #1A1A1D;
    --table-row-alt: #131316;
    --code-bg: #1A1A1D;
    --chip-bg: #202024;
    --row-hover: #1A1A1D;
    /* Soft-háttér változók sötét módra: a light-módú "papírszerű" halvány
       rózsaszín / sárga / zöld stb. helyett egy sötétebb, áttetsző színt
       használunk, hogy a fehér / muted szöveg olvasható legyen rajtuk. */
    --error-soft:   rgba(239, 68, 68, 0.18);
    --warning-soft: rgba(245, 158, 11, 0.18);
    --success-soft: rgba(34, 197, 94, 0.16);
    --info-soft:    rgba(59, 130, 246, 0.16);
    --yellow-soft:  rgba(242, 183, 5, 0.16);
}
html, body {
    font-family: var(--font-sans);
    background: var(--bg);
    color: var(--text);
    font-feature-settings: 'cv11', 'ss01';
    letter-spacing: -0.005em;
    -webkit-font-smoothing: antialiased;
}
/* Prevent theme flash on first paint (set early in <head>) */
html { color-scheme: light dark; }
/* Alpine cloak */
[x-cloak] { display: none !important; }
.mm-body { background: var(--bg); color: var(--text); margin: 0; min-height: 100vh; }
/* ============================================================
   Profile card (sidebar, above logout)
   Defined OUTSIDE @layer components on purpose: this guarantees
   higher cascade priority than any utility class and prevents
   regressions from accidental inheritance. Pure flex layout —
   the chip is a horizontal bar: avatar, name+handle, chevron.
   ============================================================ */
/* Profile chip — wraps a <table> for native horizontal layout. The .mm-profile-card
   itself is the bordered "card" container. */
.mm-profile-card {
    display: block;
    padding: 8px 10px;
    border-radius: 10px;
    border: 1px solid var(--border);
    background: transparent;
    text-decoration: none;
    color: inherit;
    transition: background .15s ease, border-color .15s ease;
}
.mm-profile-card:hover {
    background: var(--row-hover);
    border-color: var(--border-strong, var(--border));
}
.mm-profile-card:focus-visible {
    outline: 2px solid var(--yellow);
    outline-offset: 2px;
}
.mm-profile-card__avatar {
    position: relative;
    width: 36px;
    height: 36px;
}
.mm-profile-card__avatar img {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    -o-object-fit: cover;
       object-fit: cover;
    display: block;
}
.mm-profile-card__avatar .mm-avatar {
    width: 36px;
    height: 36px;
    font-size: 14px;
}
.mm-profile-card__name {
    font-size: 13px;
    font-weight: 600;
    color: var(--text);
    line-height: 1.25;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.mm-profile-card__handle {
    font-size: 11px;
    color: var(--text-muted);
    line-height: 1.2;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.mm-profile-card__arrow {
    width: 14px;
    height: 14px;
    color: var(--text-subtle);
    transition: transform .15s ease;
}
.mm-profile-card:hover .mm-profile-card__arrow {
    transform: translateX(2px);
}
/* Notification badge (small red pill on the avatar). The parent
   `.mm-profile-card__avatar` is position:relative, so this sits
   anchored to its top-right corner. */
.mm-profile-card__badge {
    position: absolute;
    top: -4px;
    right: -4px;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    border-radius: 10px;
    background: var(--error);
    color: #fff;
    font-size: 10.5px;
    font-weight: 700;
    line-height: 18px;
    text-align: center;
    box-shadow: 0 1px 3px rgba(0,0,0,.25);
    text-decoration: none;
    pointer-events: none;
}
/* ============================================================
   Login page
   ============================================================ */
.mm-login {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 1fr 440px;
    background: var(--bg);
}
.mm-login-hero {
    position: relative;
    overflow: hidden;
    padding: 56px 56px 48px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 24px;
    background: linear-gradient(145deg, #FFFBEB 0%, #FAF6E7 45%, #FFFFFF 100%);
    color: #1A1A1A;
}
[data-theme='dark'] .mm-login-hero {
    background: linear-gradient(145deg, #0A0A0A 0%, #141210 50%, #0A0A0A 100%);
    color: #F5F5F5;
}
.mm-login-hero-logo { align-self: flex-start; margin-left: -14px; }
.mm-login-eyebrow {
    font-size: 12px;
    letter-spacing: 0.14em;
    color: var(--yellow);
    font-weight: 700;
    margin-bottom: 14px;
}
.mm-login-headline {
    font-size: clamp(30px, 5vw, 52px);
    line-height: 1.02;
    margin: 0;
    letter-spacing: -0.03em;
    font-weight: 800;
    color: inherit;
}
.mm-login-sub {
    font-size: clamp(14px, 1.7vw, 16px);
    max-width: 460px;
    margin-top: 22px;
    line-height: 1.6;
    color: var(--text-muted);
}
[data-theme='dark'] .mm-login-sub { color: #B5B0A8; }
.mm-login-brand {
    display: flex;
    align-items: center;
    gap: 12px;
    z-index: 1;
}
.mm-login-tagline {
    max-width: 520px;
    z-index: 1;
}
.mm-login-hero-footer {
    font-size: 11px;
    color: var(--text-subtle);
    z-index: 1;
}
.mm-login-hero-footer-link {
    color: inherit;
    text-decoration: underline;
    text-decoration-color: var(--yellow);
    text-underline-offset: 2px;
    transition: color .12s;
}
.mm-login-hero-footer-link:hover { color: var(--yellow); }
.mm-login-stripes {
    position: absolute;
    right: -60px;
    top: -60px;
    width: 320px;
    height: 320px;
    opacity: 0.08;
    background: repeating-linear-gradient(45deg, var(--yellow) 0 6px, transparent 6px 16px);
    border-radius: 50%;
    pointer-events: none;
}
.mm-login-card {
    background: var(--card);
    border-left: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    padding: 48px 44px;
    gap: 24px;
}
.mm-login-card-top {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}
.mm-login-compact-brand {
    display: none;
    align-items: center;
    gap: 10px;
}
.mm-login-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 24px;
    justify-content: center;
}
/* Daily quote — featured presentation on login hero (big, yellow-bar, serif mark) */
.mm-quote-featured {
    margin-top: 52px;
    max-width: 640px;
    border-left: 4px solid var(--yellow);
    padding: 6px 0 6px 28px;
    position: relative;
}
.mm-quote-featured-mark {
    position: absolute;
    left: 4px;
    top: -30px;
    font-family: Georgia, 'Times New Roman', serif;
    font-weight: 700;
    font-size: 100px;
    line-height: 1;
    color: var(--yellow);
    opacity: 0.5;
    pointer-events: none;
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
}
.mm-quote-featured-body { position: relative; z-index: 1; }
.mm-quote-featured-label {
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--yellow);
    font-weight: 700;
    margin-bottom: 12px;
}
.mm-quote-featured-text {
    margin: 0;
    font-size: clamp(18px, 2vw, 24px);
    line-height: 1.35;
    font-weight: 500;
    letter-spacing: -0.015em;
    text-wrap: pretty;
    color: inherit;
}
.mm-quote-featured-author {
    margin: 14px 0 0;
    font-size: 14px;
    font-style: italic;
    color: var(--text-muted);
}
[data-theme='dark'] .mm-quote-featured-text { color: #F0EAE0; }
[data-theme='dark'] .mm-quote-featured-author { color: #8B8680; }
/* Legacy compact quote used elsewhere */
.mm-quote-big {
    margin-top: 40px;
    max-width: 560px;
    border-left: 3px solid var(--yellow);
    padding: 6px 0 6px 22px;
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: 0;
}
.mm-quote-bigmark {
    position: absolute;
    left: -4px;
    top: -22px;
    font-family: Georgia, 'Times New Roman', serif;
    font-weight: 700;
    font-size: 72px;
    line-height: 1;
    color: var(--yellow);
    opacity: 0.35;
    pointer-events: none;
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
}
.mm-quote-bigbody { position: relative; z-index: 1; }
.mm-quote-biglabel {
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--yellow);
    font-weight: 700;
    margin-bottom: 8px;
}
.mm-quote-bigtext {
    margin: 0;
    font-size: clamp(15px, 1.7vw, 19px);
    line-height: 1.45;
    color: var(--text);
    font-weight: 500;
    letter-spacing: -0.005em;
    text-wrap: pretty;
}
.mm-quote-mobile { display: none; margin-top: 22px; }
/* Mobile-only quote card (shown on login when hero is hidden) */
.mm-quote-mobile-card {
    display: none;
    margin-top: 6px;
    padding: 12px 14px;
    border-left: 3px solid var(--yellow);
    background: rgba(242,183,5,0.06);
    border-radius: 0 8px 8px 0;
}
.mm-quote-mobile-label {
    font-size: 9.5px;
    letter-spacing: 0.12em;
    color: var(--yellow);
    font-weight: 700;
    text-transform: uppercase;
    margin-bottom: 4px;
}
.mm-quote-mobile-text {
    margin: 0;
    font-size: 12.5px;
    font-weight: 500;
    line-height: 1.4;
    text-wrap: pretty;
    color: var(--text);
}
.mm-quote-mobile-author {
    margin: 5px 0 0;
    font-size: 10.5px;
    color: var(--text-muted);
    font-style: italic;
}
/* Dashboard motivation strip */
.mm-quote-strip {
    display: flex;
    align-items: center;
    gap: 18px;
    padding: 14px 20px;
    margin-bottom: 20px;
    background: linear-gradient(90deg, rgba(242,183,5,0.12) 0%, rgba(242,183,5,0.03) 40%, transparent 100%);
    border: 1px solid var(--border);
    border-left: 3px solid var(--yellow);
    border-radius: 10px;
}
.mm-quote-strip-badge {
    width: 36px; height: 36px; flex-shrink: 0;
    border-radius: 50%;
    background: rgba(242,183,5,0.18);
    color: var(--yellow);
    display: grid;
    place-items: center;
    font-family: Georgia, 'Times New Roman', serif;
    font-size: 28px;
    font-weight: 700;
    line-height: 1;
    padding-bottom: 6px;
}
.mm-quote-strip-body { flex: 1; min-width: 0; }
.mm-quote-strip-label {
    font-size: 10px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--yellow);
    font-weight: 700;
    margin-bottom: 3px;
}
.mm-quote-strip-text {
    margin: 0;
    font-size: 14.5px;
    font-weight: 500;
    line-height: 1.4;
    letter-spacing: -0.005em;
    text-wrap: pretty;
    color: var(--text);
}
/* ============================================================
   Mobile / responsive
   ============================================================ */
/* Login: stack on smaller viewports. Hero shrinks to a compact header;
   the quote moves from hero into the bottom of the login card on phones. */
@media (max-width: 960px) {
    .mm-login { grid-template-columns: 1fr; }
    .mm-login-hero {
        padding: 28px 24px;
        min-height: auto;
        gap: 18px;
    }
    .mm-login-hero h1 { font-size: 28px !important; }
    .mm-login-hero-footer { display: none; }
    .mm-login-card { padding: 28px 24px; border-left: 0; border-top: 1px solid var(--border); gap: 16px; }
    .mm-login-card-top { display: none; }
    .mm-login-compact-brand { display: flex; }
    .mm-login-body { justify-content: flex-start; }
    .mm-quote-big { margin-top: 24px; }
    .mm-login-hero-logo { margin-left: 0; align-self: center; }

    /* Hero quote hides on tablet-and-down; mobile card takes over in the form panel */
    .mm-quote-featured { display: none; }
    .mm-quote-mobile-card { display: block; }
}
@media (max-width: 640px) {
    /* On phones hide the big hero entirely — compact brand row is in the card. */
    .mm-login-hero { display: none; }
    .mm-login-card { padding: 24px 20px 28px; }
    .mm-login-body { gap: 18px; }
    .mm-login-card-top { display: flex; position: absolute; top: 14px; right: 16px; z-index: 2; }
    .mm-login { position: relative; }
}
@media (max-width: 960px) {
    /* On mobile we ignore the desktop-collapsed state entirely — the drawer
       is always off-canvas by default and only opens via the Alpine
       is-mobile-open class. */
    .mm-shell,
    html[data-sidebar='hidden'] .mm-shell { grid-template-columns: 1fr; }

    /* Hide desktop hamburger — mobile has a bottom "Menü" button instead. */
    .mm-hamburger { display: none; }

    /* Bottom nav visible on mobile */
    .mm-bottom-nav {
        display: grid;
        grid-template-columns: repeat(5, 1fr);
        position: sticky;
        bottom: 0;
        background: var(--bg-soft);
        border-top: 1px solid var(--border);
        padding: 4px 0 max(6px, env(safe-area-inset-bottom));
        z-index: 20;
        flex-shrink: 0;
    }

    /* Leave room so the last row of content isn't hidden behind the bottom nav */
    .mm-content { padding-bottom: 24px; }

    .mm-sidebar,
    html[data-sidebar='hidden'] .mm-shell .mm-sidebar {
        position: fixed;
        top: 0; left: 0; bottom: 0;
        width: 260px;
        z-index: 50;
        transform: translateX(-100%);
        box-shadow: var(--shadow-lg);
        border-right-color: var(--border);
    }
    .mm-shell.is-mobile-open .mm-sidebar,
    html[data-sidebar='hidden'] .mm-shell.is-mobile-open .mm-sidebar {
        transform: translateX(0);
    }

    .mm-topbar { padding: 12px 16px; }
    .mm-content { padding: 16px; }

    .mm-crumbs-root { display: none; }
    .mm-crumbs-sep { display: none; }

    .mm-sb-item { padding: 12px 12px; font-size: 14px; }
    .mm-sb-item.active::before { left: -14px; top: 10px; bottom: 10px; }

    /* On mobile the topbar quick-icons disappear and the sidebar carries those
       links again — same UX as before this refactor. */
    .mm-topbar-quick { display: none; }
    .mm-sb-item.is-desktop-hidden { display: flex; }

    /* Make POS/product layouts stack */
    .mm-stack-mobile { grid-template-columns: 1fr !important; }

    /* Buttons get bigger tap targets on mobile */
    .mm-btn { min-height: 40px; padding: 0 14px; }
    .mm-btn-sm { min-height: 32px; }
    .mm-btn-lg { min-height: 48px; }
    .mm-input, .mm-select, .mm-textarea { padding: 11px 12px; font-size: 14px; }
    .mm-icon-btn { width: 40px; height: 40px; }

    /* Card spacing is tighter on mobile */
    .mm-card-bd { padding: 14px; }
    .mm-card-hd { padding: 12px 14px; }

    /* Tables get horizontal scroll on mobile but with better UX */
    .mm-table th, .mm-table td { padding: 10px; }

    /* KPI grid: 2 columns on tablet, full width on phones */
    .mm-kpi { min-height: 96px; padding: 14px; }
    .mm-kpi-value { font-size: 24px; }
}
@media (max-width: 480px) {
    .mm-sidebar { width: min(280px, calc(100vw - 48px)); }
    .mm-content { padding: 12px; }
    .mm-topbar { padding: 10px 14px; gap: 8px; }
    .mm-kpi-value { font-size: 22px; }
    h1.mm-page-title, .mm-page-title { font-size: 20px !important; }
}
/* Surface color helpers for use in utility-class contexts */
.bg-surface { background: var(--bg); }
.bg-surface-soft { background: var(--bg-soft); }
.bg-surface-card { background: var(--card); }
.text-surface { color: var(--text); }
.text-surface-muted { color: var(--text-muted); }
.text-surface-subtle { color: var(--text-subtle); }
.border-surface { border-color: var(--border); }
.border-surface-strong { border-color: var(--border-strong); }
/* ============================
   WYSIWYG (Trix) theme wrapper
   ============================ */
.mm-wysiwyg trix-toolbar {
    background: var(--card);
    border: 1px solid var(--border);
    border-bottom: none;
    border-radius: 8px 8px 0 0;
    padding: 6px;
}
.mm-wysiwyg trix-toolbar .trix-button-row {
    display: flex;
    flex-wrap: wrap;
    gap: 2px;
}
.mm-wysiwyg trix-toolbar .trix-button-group {
    border: none;
    background: transparent;
    margin: 0 2px 0 0;
}
.mm-wysiwyg trix-toolbar .trix-button {
    border: 1px solid transparent;
    border-radius: 6px;
    background: transparent;
    color: var(--text);
    height: 28px;
    min-width: 28px;
    padding: 2px 8px;
}
.mm-wysiwyg trix-toolbar .trix-button:not(:first-child) {
    border-left: 1px solid transparent;
}
.mm-wysiwyg trix-toolbar .trix-button::before {
    filter: invert(0);
    opacity: 0.75;
}
[data-theme="dark"] .mm-wysiwyg trix-toolbar .trix-button::before {
    filter: invert(1);
    opacity: 0.85;
}
.mm-wysiwyg trix-toolbar .trix-button:hover {
    background: var(--bg-soft);
    border-color: var(--border);
}
.mm-wysiwyg trix-toolbar .trix-button.trix-active {
    background: var(--yellow-soft);
    border-color: var(--yellow);
    color: #7A4E00;
}
[data-theme="dark"] .mm-wysiwyg trix-toolbar .trix-button.trix-active::before {
    filter: invert(0);
}
.mm-wysiwyg trix-toolbar .trix-dialog {
    background: var(--card);
    border-top: 1px solid var(--border);
    color: var(--text);
}
.mm-wysiwyg trix-toolbar .trix-input {
    background: var(--bg-soft);
    color: var(--text);
    border: 1px solid var(--border);
    border-radius: 6px;
}
.mm-wysiwyg trix-editor {
    display: block;
    min-height: 160px;
    padding: 12px 14px;
    background: var(--card);
    color: var(--text);
    border: 1px solid var(--border);
    border-radius: 0 0 8px 8px;
    font-size: 14px;
    line-height: 1.5;
    outline: none;
}
.mm-wysiwyg trix-editor:focus {
    border-color: var(--yellow);
    box-shadow: 0 0 0 2px rgba(242,183,5,0.15);
}
.mm-wysiwyg trix-editor h1 {
    font-size: 18px;
    font-weight: 700;
    margin: 10px 0 6px;
}
.mm-wysiwyg trix-editor ul,
.mm-wysiwyg trix-editor ol {
    padding-left: 22px;
    margin: 6px 0;
}
.mm-wysiwyg trix-editor blockquote {
    border-left: 3px solid var(--yellow);
    padding-left: 10px;
    color: var(--text-muted);
    margin: 8px 0;
}
.mm-wysiwyg trix-editor a {
    color: var(--yellow);
    text-decoration: underline;
}
.mm-wysiwyg trix-editor pre {
    background: var(--bg-soft);
    padding: 8px 10px;
    border-radius: 6px;
    font-family: 'JetBrains Mono', ui-monospace, monospace;
    font-size: 12.5px;
}
.mm-wysiwyg-readonly {
    padding: 12px 14px;
    background: var(--card);
    color: var(--text);
    border: 1px solid var(--border);
    border-radius: 8px;
    font-size: 14px;
    line-height: 1.5;
    min-height: 60px;
}
.mm-wysiwyg-readonly a { color: var(--yellow); text-decoration: underline; }
.mm-wysiwyg-readonly ul, .mm-wysiwyg-readonly ol { padding-left: 22px; margin: 6px 0; }
.mm-wysiwyg-readonly blockquote { border-left: 3px solid var(--yellow); padding-left: 10px; color: var(--text-muted); margin: 8px 0; }
/* ============ Paginator (mm) ============ */
.mm-pagination {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    flex-wrap: wrap;
}
.mm-pagination .mm-pagination-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 30px;
    height: 30px;
    padding: 0 10px;
    font-size: 12.5px;
    color: var(--text);
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 6px;
    text-decoration: none;
    transition: background .12s, border-color .12s;
}
.mm-pagination .mm-pagination-btn:hover {
    background: var(--bg-soft);
    border-color: var(--border-strong);
}
.mm-pagination .mm-pagination-current {
    background: var(--yellow);
    color: #1A1A1A;
    border-color: var(--yellow);
    font-weight: 600;
    cursor: default;
}
.mm-pagination .mm-pagination-disabled {
    color: var(--text-subtle);
    background: var(--bg-sunken);
    cursor: default;
}
.mm-pagination .mm-pagination-ellipsis {
    color: var(--text-subtle);
    font-size: 12.5px;
    padding: 0 4px;
}
/* Dim rows in product lists (no stock anywhere) */
.mm-row-dim {
    opacity: 0.55;
}
.mm-row-dim:hover {
    opacity: 0.8;
}
/* Orders list — "Elfogadásra vár" rows: only a thick left accent bar, no background tint */
.mm-table tbody tr.mm-row-pending td:first-child { box-shadow: inset 5px 0 0 var(--warning); }
/* Orders list — closed/resolved rows: faded */
.mm-table tbody tr.mm-row-closed { opacity: 0.65; }
.mm-table tbody tr.mm-row-closed:hover { opacity: 0.9; }
/* ========= Fixed sidebar on desktop =========
   The sidebar sticks to the viewport (top:0, height:100vh) so it stays put
   while the right-hand content scrolls. Footer already pins to bottom via
   flex margin-top:auto; internal overflow handles low-resolution screens.
*/
@media (min-width: 768px) {
    .mm-shell {
        align-items: start;
    }
    .mm-sidebar {
        position: sticky;
        top: 0;
        height: 100vh;
        max-height: 100vh;
        align-self: start;
    }
}
.selection\:bg-\[\#FF2D20\] *::-moz-selection{
  --tw-bg-opacity: 1;
  background-color: rgb(255 45 32 / var(--tw-bg-opacity, 1));
}
.selection\:bg-\[\#FF2D20\] *::selection{
  --tw-bg-opacity: 1;
  background-color: rgb(255 45 32 / var(--tw-bg-opacity, 1));
}
.selection\:text-white *::-moz-selection{
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}
.selection\:text-white *::selection{
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}
.selection\:bg-\[\#FF2D20\]::-moz-selection{
  --tw-bg-opacity: 1;
  background-color: rgb(255 45 32 / var(--tw-bg-opacity, 1));
}
.selection\:bg-\[\#FF2D20\]::selection{
  --tw-bg-opacity: 1;
  background-color: rgb(255 45 32 / var(--tw-bg-opacity, 1));
}
.selection\:text-white::-moz-selection{
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}
.selection\:text-white::selection{
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}
.hover\:text-black:hover{
  --tw-text-opacity: 1;
  color: rgb(0 0 0 / var(--tw-text-opacity, 1));
}
.hover\:text-black\/70:hover{
  color: rgb(0 0 0 / 0.7);
}
.hover\:text-gray-400:hover{
  --tw-text-opacity: 1;
  color: rgb(156 163 175 / var(--tw-text-opacity, 1));
}
.hover\:text-gray-500:hover{
  --tw-text-opacity: 1;
  color: rgb(107 114 128 / var(--tw-text-opacity, 1));
}
.hover\:ring-black\/20:hover{
  --tw-ring-color: rgb(0 0 0 / 0.2);
}
.focus\:z-10:focus{
  z-index: 10;
}
.focus\:border-blue-300:focus{
  --tw-border-opacity: 1;
  border-color: rgb(147 197 253 / var(--tw-border-opacity, 1));
}
.focus\:outline-none:focus{
  outline: 2px solid transparent;
  outline-offset: 2px;
}
.focus\:ring:focus{
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}
.focus-visible\:ring-1:focus-visible{
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}
.focus-visible\:ring-\[\#FF2D20\]:focus-visible{
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(255 45 32 / var(--tw-ring-opacity, 1));
}
.active\:bg-gray-100:active{
  --tw-bg-opacity: 1;
  background-color: rgb(243 244 246 / var(--tw-bg-opacity, 1));
}
.active\:text-gray-500:active{
  --tw-text-opacity: 1;
  color: rgb(107 114 128 / var(--tw-text-opacity, 1));
}
.active\:text-gray-700:active{
  --tw-text-opacity: 1;
  color: rgb(55 65 81 / var(--tw-text-opacity, 1));
}
@media (min-width: 640px){
  .sm\:flex{
    display: flex;
  }
  .sm\:hidden{
    display: none;
  }
  .sm\:size-16{
    width: 4rem;
    height: 4rem;
  }
  .sm\:size-6{
    width: 1.5rem;
    height: 1.5rem;
  }
  .sm\:flex-1{
    flex: 1 1 0%;
  }
  .sm\:items-center{
    align-items: center;
  }
  .sm\:justify-between{
    justify-content: space-between;
  }
  .sm\:pt-5{
    padding-top: 1.25rem;
  }
}
@media (min-width: 768px){
  .md\:row-span-3{
    grid-row: span 3 / span 3;
  }
}
@media (min-width: 1024px){
  .lg\:col-start-2{
    grid-column-start: 2;
  }
  .lg\:h-16{
    height: 4rem;
  }
  .lg\:max-w-7xl{
    max-width: 80rem;
  }
  .lg\:grid-cols-2{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .lg\:grid-cols-3{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .lg\:flex-col{
    flex-direction: column;
  }
  .lg\:items-end{
    align-items: flex-end;
  }
  .lg\:justify-center{
    justify-content: center;
  }
  .lg\:gap-8{
    gap: 2rem;
  }
  .lg\:p-10{
    padding: 2.5rem;
  }
  .lg\:pb-10{
    padding-bottom: 2.5rem;
  }
  .lg\:pt-0{
    padding-top: 0px;
  }
  .lg\:text-\[\#FF2D20\]{
    --tw-text-opacity: 1;
    color: rgb(255 45 32 / var(--tw-text-opacity, 1));
  }
}
.rtl\:flex-row-reverse:where([dir="rtl"], [dir="rtl"] *){
  flex-direction: row-reverse;
}
@media (prefers-color-scheme: dark){
  .dark\:block{
    display: block;
  }
  .dark\:hidden{
    display: none;
  }
  .dark\:border-gray-600{
    --tw-border-opacity: 1;
    border-color: rgb(75 85 99 / var(--tw-border-opacity, 1));
  }
  .dark\:bg-black{
    --tw-bg-opacity: 1;
    background-color: rgb(0 0 0 / var(--tw-bg-opacity, 1));
  }
  .dark\:bg-gray-800{
    --tw-bg-opacity: 1;
    background-color: rgb(31 41 55 / var(--tw-bg-opacity, 1));
  }
  .dark\:bg-zinc-900{
    --tw-bg-opacity: 1;
    background-color: rgb(24 24 27 / var(--tw-bg-opacity, 1));
  }
  .dark\:via-zinc-900{
    --tw-gradient-to: rgb(24 24 27 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), #18181b var(--tw-gradient-via-position), var(--tw-gradient-to);
  }
  .dark\:to-zinc-900{
    --tw-gradient-to: #18181b var(--tw-gradient-to-position);
  }
  .dark\:text-gray-300{
    --tw-text-opacity: 1;
    color: rgb(209 213 219 / var(--tw-text-opacity, 1));
  }
  .dark\:text-gray-400{
    --tw-text-opacity: 1;
    color: rgb(156 163 175 / var(--tw-text-opacity, 1));
  }
  .dark\:text-gray-600{
    --tw-text-opacity: 1;
    color: rgb(75 85 99 / var(--tw-text-opacity, 1));
  }
  .dark\:text-white{
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity, 1));
  }
  .dark\:text-white\/50{
    color: rgb(255 255 255 / 0.5);
  }
  .dark\:text-white\/70{
    color: rgb(255 255 255 / 0.7);
  }
  .dark\:ring-zinc-800{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(39 39 42 / var(--tw-ring-opacity, 1));
  }
  .dark\:hover\:text-gray-300:hover{
    --tw-text-opacity: 1;
    color: rgb(209 213 219 / var(--tw-text-opacity, 1));
  }
  .dark\:hover\:text-white:hover{
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity, 1));
  }
  .dark\:hover\:text-white\/70:hover{
    color: rgb(255 255 255 / 0.7);
  }
  .dark\:hover\:text-white\/80:hover{
    color: rgb(255 255 255 / 0.8);
  }
  .dark\:hover\:ring-zinc-700:hover{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(63 63 70 / var(--tw-ring-opacity, 1));
  }
  .dark\:focus\:border-blue-700:focus{
    --tw-border-opacity: 1;
    border-color: rgb(29 78 216 / var(--tw-border-opacity, 1));
  }
  .dark\:focus\:border-blue-800:focus{
    --tw-border-opacity: 1;
    border-color: rgb(30 64 175 / var(--tw-border-opacity, 1));
  }
  .dark\:focus-visible\:ring-\[\#FF2D20\]:focus-visible{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(255 45 32 / var(--tw-ring-opacity, 1));
  }
  .dark\:focus-visible\:ring-white:focus-visible{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(255 255 255 / var(--tw-ring-opacity, 1));
  }
  .dark\:active\:bg-gray-700:active{
    --tw-bg-opacity: 1;
    background-color: rgb(55 65 81 / var(--tw-bg-opacity, 1));
  }
  .dark\:active\:text-gray-300:active{
    --tw-text-opacity: 1;
    color: rgb(209 213 219 / var(--tw-text-opacity, 1));
  }
}
