/* ============================================================
   MoBiz POS — tailwind.offline.css
   Generated from actual classes used across the app.
   Precached by service-worker.js so the app works fully offline
   even when a CDN is unavailable.
   ============================================================ */

/* ------------------------------------------------------------
   PREFLIGHT RESET
   ------------------------------------------------------------ */
*,::before,::after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}
html{line-height:1.5;-webkit-text-size-adjust:100%;tab-size:4;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif}
body{margin:0;line-height:inherit}
h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}
a{color:inherit;text-decoration:inherit}
b,strong{font-weight:bolder}
button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}
button,[role=button]{cursor:pointer}
button{background-color:transparent;background-image:none}
:-moz-focusring{outline:auto}
:-moz-ui-invalid{box-shadow:none}
progress{vertical-align:baseline}
::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}
[type=search]{-webkit-appearance:textfield;outline-offset:-2px}
::-webkit-search-decoration{-webkit-appearance:none}
::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}
summary{display:list-item}
blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}
fieldset{margin:0;padding:0}
legend{padding:0}
ol,ul,menu{list-style:none;margin:0;padding:0}
textarea{resize:vertical}
input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}
img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}
img,video{max-width:100%;height:auto}
[hidden]{display:none}

/* ------------------------------------------------------------
   ANIMATIONS
   ------------------------------------------------------------ */
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{50%{opacity:.5}}
@keyframes bounce{0%,100%{transform:translateY(-25%);animation-timing-function:cubic-bezier(.8,0,1,1)}50%{transform:none;animation-timing-function:cubic-bezier(0,0,.2,1)}}
@keyframes slide-in-from-bottom{from{transform:translateY(100%)}to{transform:translateY(0)}}

.animate-spin{animation:spin 1s linear infinite}
.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}
.animate-bounce{animation:bounce 1s infinite}
.animate-in{animation-fill-mode:both}
.slide-in-from-bottom{animation:slide-in-from-bottom .3s ease-out}

/* ------------------------------------------------------------
   DISPLAY
   ------------------------------------------------------------ */
.block{display:block}
.inline-block{display:inline-block}
.inline-flex{display:inline-flex}
.flex{display:flex}
.grid{display:grid}
.hidden{display:none}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}

/* ------------------------------------------------------------
   FLEXBOX
   ------------------------------------------------------------ */
.flex-1{flex:1 1 0%}
.flex-col{flex-direction:column}
.flex-wrap{flex-wrap:wrap}
.shrink-0{flex-shrink:0}
.items-start{align-items:flex-start}
.items-center{align-items:center}
.items-end{align-items:flex-end}
.justify-start{justify-content:flex-start}
.justify-center{justify-content:center}
.justify-end{justify-content:flex-end}
.justify-between{justify-content:space-between}
.justify-around{justify-content:space-around}
.place-items-center{place-items:center}
.gap-1{gap:.25rem}
.gap-1\.5{gap:.375rem}
.gap-2{gap:.5rem}
.gap-3{gap:.75rem}
.gap-4{gap:1rem}

/* ------------------------------------------------------------
   GRID
   ------------------------------------------------------------ */
.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}
.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.col-span-2{grid-column:span 2/span 2}
.col-span-full{grid-column:1/-1}

/* ------------------------------------------------------------
   SPACING — MARGIN
   ------------------------------------------------------------ */
.m-0{margin:0}
.mx-1{margin-left:.25rem;margin-right:.25rem}
.mx-4{margin-left:1rem;margin-right:1rem}
.mx-auto{margin-left:auto;margin-right:auto}
.my-1{margin-top:.25rem;margin-bottom:.25rem}
.my-2{margin-top:.5rem;margin-bottom:.5rem}
.mt-0{margin-top:0}
.mt-0\.5{margin-top:.125rem}
.mt-1{margin-top:.25rem}
.mt-2{margin-top:.5rem}
.mt-3{margin-top:.75rem}
.mt-4{margin-top:1rem}
.mt-6{margin-top:1.5rem}
.mt-7{margin-top:1.75rem}
.mb-0\.5{margin-bottom:.125rem}
.mb-1{margin-bottom:.25rem}
.mb-2{margin-bottom:.5rem}
.mb-3{margin-bottom:.75rem}
.mb-4{margin-bottom:1rem}
.mb-5{margin-bottom:1.25rem}
.mb-6{margin-bottom:1.5rem}
.mb-8{margin-bottom:2rem}
.ml-1{margin-left:.25rem}
.ml-2{margin-left:.5rem}
.ml-auto{margin-left:auto}

/* ------------------------------------------------------------
   SPACING — PADDING
   ------------------------------------------------------------ */
.p-0{padding:0}
.p-1\.5{padding:.375rem}
.p-2{padding:.5rem}
.p-3{padding:.75rem}
.p-4{padding:1rem}
.p-5{padding:1.25rem}
.p-6{padding:1.5rem}
.p-8{padding:2rem}
.p-12{padding:3rem}
.px-1{padding-left:.25rem;padding-right:.25rem}
.px-1\.5{padding-left:.375rem;padding-right:.375rem}
.px-2{padding-left:.5rem;padding-right:.5rem}
.px-3{padding-left:.75rem;padding-right:.75rem}
.px-4{padding-left:1rem;padding-right:1rem}
.px-5{padding-left:1.25rem;padding-right:1.25rem}
.px-6{padding-left:1.5rem;padding-right:1.5rem}
.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}
.py-1{padding-top:.25rem;padding-bottom:.25rem}
.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}
.py-2{padding-top:.5rem;padding-bottom:.5rem}
.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}
.py-3{padding-top:.75rem;padding-bottom:.75rem}
.py-3\.5{padding-top:.875rem;padding-bottom:.875rem}
.py-4{padding-top:1rem;padding-bottom:1rem}
.py-5{padding-top:1.25rem;padding-bottom:1.25rem}
.py-6{padding-top:1.5rem;padding-bottom:1.5rem}
.py-8{padding-top:2rem;padding-bottom:2rem}
.py-12{padding-top:3rem;padding-bottom:3rem}
.pt-0{padding-top:0}
.pt-1{padding-top:.25rem}
.pt-2{padding-top:.5rem}
.pt-3{padding-top:.75rem}
.pt-4{padding-top:1rem}
.pt-5{padding-top:1.25rem}
.pt-6{padding-top:1.5rem}
.pt-8{padding-top:2rem}
.pt-16{padding-top:4rem}
.pb-1{padding-bottom:.25rem}
.pb-2{padding-bottom:.5rem}
.pb-3{padding-bottom:.75rem}
.pb-4{padding-bottom:1rem}
.pb-10{padding-bottom:2.5rem}
.pb-12{padding-bottom:3rem}
.pb-24{padding-bottom:6rem}
.pb-28{padding-bottom:7rem}
.pb-\[env\(safe-area-inset-bottom\)\]{padding-bottom:env(safe-area-inset-bottom)}
.pl-5{padding-left:1.25rem}
.pl-6{padding-left:1.5rem}
.pl-12{padding-left:3rem}
.pr-1{padding-right:.25rem}
.pr-2{padding-right:.5rem}

/* ------------------------------------------------------------
   POSITION
   ------------------------------------------------------------ */
.static{position:static}
.fixed{position:fixed}
.absolute{position:absolute}
.relative{position:relative}
.sticky{position:sticky}
.inset-0{inset:0}
.inset-x-0{left:0;right:0}
.inset-x-3{left:.75rem;right:.75rem}
.top-0{top:0}
.top-0\.5{top:.125rem}
.top-1\/2{top:50%}
.top-8{top:2rem}
.top-\[10px\]{top:10px}
.top-\[52px\]{top:52px}
.right-0{right:0}
.right-2{right:.5rem}
.right-3{right:.75rem}
.bottom-0{bottom:0}
.bottom-2{bottom:.5rem}
.bottom-3{bottom:.75rem}
.bottom-\[90px\]{bottom:90px}
.left-0{left:0}
.left-0\.5{left:.125rem}
.left-1\/2{left:50%}
.left-2{left:.5rem}
.left-\[2px\]{left:2px}

/* ------------------------------------------------------------
   SIZING — WIDTH
   ------------------------------------------------------------ */
.w-1{width:.25rem}
.w-2{width:.5rem}
.w-4{width:1rem}
.w-5{width:1.25rem}
.w-6{width:1.5rem}
.w-7{width:1.75rem}
.w-8{width:2rem}
.w-10{width:2.5rem}
.w-11{width:2.75rem}
.w-12{width:3rem}
.w-14{width:3.5rem}
.w-16{width:4rem}
.w-28{width:7rem}
.w-72{width:18rem}
.w-1\/2{width:50%}
.w-full{width:100%}
.w-\[420px\]{width:420px}
.w-\[86\%\]{width:86%}
.min-w-0{min-width:0}
.min-w-full{min-width:100%}
.min-w-\[1\.2rem\]{min-width:1.2rem}
.min-w-\[1\.6rem\]{min-width:1.6rem}
.min-w-\[20px\]{min-width:20px}
.min-w-\[40px\]{min-width:40px}
.min-w-\[44px\]{min-width:44px}
.max-w-xs{max-width:20rem}
.max-w-md{max-width:28rem}
.max-w-lg{max-width:32rem}
.max-w-xl{max-width:36rem}
.max-w-2xl{max-width:42rem}
.max-w-full{max-width:100%}
.max-w-screen-sm{max-width:640px}
.max-w-screen-md{max-width:768px}
.max-w-screen-lg{max-width:1024px}
.max-w-\[360px\]{max-width:360px}
.max-w-\[760px\]{max-width:760px}
.max-w-\[85\%\]{max-width:85%}
.max-w-\[980px\]{max-width:980px}

/* ------------------------------------------------------------
   SIZING — HEIGHT
   ------------------------------------------------------------ */
.h-2{height:.5rem}
.h-2\.5{height:.625rem}
.h-4{height:1rem}
.h-5{height:1.25rem}
.h-6{height:1.5rem}
.h-7{height:1.75rem}
.h-8{height:2rem}
.h-9{height:2.25rem}
.h-10{height:2.5rem}
.h-11{height:2.75rem}
.h-12{height:3rem}
.h-13{height:3.25rem}
.h-14{height:3.5rem}
.h-16{height:4rem}
.h-24{height:6rem}
.h-40{height:10rem}
.h-auto{height:auto}
.h-full{height:100%}
.h-px{height:1px}
.h-screen{height:100vh}
.min-h-screen{min-height:100vh}
.min-h-\[1\.2em\]{min-height:1.2em}
.max-h-44{max-height:11rem}
.max-h-64{max-height:16rem}
.max-h-72{max-height:18rem}
.max-h-full{max-height:100%}
.max-h-\[280px\]{max-height:280px}
.max-h-\[60vh\]{max-height:60vh}
.max-h-\[80vh\]{max-height:80vh}
.max-h-\[90vh\]{max-height:90vh}
.aspect-\[1\.585\/1\]{aspect-ratio:1.585/1}
.aspect-\[4\/3\]{aspect-ratio:4/3}

/* ------------------------------------------------------------
   TYPOGRAPHY
   ------------------------------------------------------------ */
.text-xs{font-size:.75rem;line-height:1rem}
.text-sm{font-size:.875rem;line-height:1.25rem}
.text-base{font-size:1rem;line-height:1.5rem}
.text-lg{font-size:1.125rem;line-height:1.75rem}
.text-xl{font-size:1.25rem;line-height:1.75rem}
.text-2xl{font-size:1.5rem;line-height:2rem}
.text-3xl{font-size:1.875rem;line-height:2.25rem}
.text-4xl{font-size:2.25rem;line-height:2.5rem}
.text-5xl{font-size:3rem;line-height:1}
.text-7xl{font-size:4.5rem;line-height:1}
.text-\[9px\]{font-size:9px}
.text-\[10px\]{font-size:10px}
.text-\[11px\]{font-size:11px}
.text-\[12px\]{font-size:12px}
.font-normal{font-weight:400}
.font-medium{font-weight:500}
.font-semibold{font-weight:600}
.font-bold{font-weight:700}
.font-extrabold{font-weight:800}
.font-black{font-weight:900}
.italic{font-style:italic}
.uppercase{text-transform:uppercase}
.lowercase{text-transform:lowercase}
.capitalize{text-transform:capitalize}
.normal-case{text-transform:none}
.underline{text-decoration-line:underline}
.leading-none{line-height:1}
.leading-tight{line-height:1.25}
.leading-snug{line-height:1.375}
.leading-relaxed{line-height:1.625}
.tracking-tight{letter-spacing:-.025em}
.tracking-tighter{letter-spacing:-.05em}
.tracking-wide{letter-spacing:.025em}
.tracking-wider{letter-spacing:.05em}
.tracking-widest{letter-spacing:.1em}
.tracking-\[0\.2em\]{letter-spacing:.2em}
.text-left{text-align:left}
.text-center{text-align:center}
.text-right{text-align:right}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.whitespace-nowrap{white-space:nowrap}
.whitespace-pre-wrap{white-space:pre-wrap}
.break-words{overflow-wrap:break-word}
.break-all{word-break:break-all}
.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}
.list-disc{list-style-type:disc}

/* ------------------------------------------------------------
   COLORS — TEXT
   ------------------------------------------------------------ */
.text-white{color:#fff}
.text-white\/50{color:rgb(255 255 255/.5)}
.text-white\/80{color:rgb(255 255 255/.8)}
.text-slate-300{color:#cbd5e1}
.text-slate-400{color:#94a3b8}
.text-slate-500{color:#64748b}
.text-slate-600{color:#475569}
.text-slate-700{color:#334155}
.text-slate-800{color:#1e293b}
.text-slate-900{color:#0f172a}
.text-rose-500{color:#f43f5e}
.text-rose-600{color:#e11d48}
.text-rose-700{color:#be123c}
.text-rose-800{color:#9f1239}
.text-rose-900{color:#881337}
.text-amber-50{color:#fffbeb}
.text-amber-500{color:#f59e0b}
.text-amber-700{color:#b45309}
.text-amber-800{color:#92400e}
.text-amber-900{color:#78350f}
.text-emerald-300{color:#6ee7b7}
.text-emerald-600{color:#059669}
.text-emerald-700{color:#047857}
.text-emerald-800{color:#065f46}
.text-indigo-300{color:#a5b4fc}
.text-indigo-500{color:#6366f1}
.text-indigo-600{color:#4f46e5}
.text-indigo-700{color:#4338ca}
.text-indigo-800{color:#3730a3}
.text-sky-700{color:#0369a1}
.text-blue-400{color:#60a5fa}
.text-purple-700{color:#7e22ce}
.text-orange-600{color:#ea580c}

/* ------------------------------------------------------------
   COLORS — BACKGROUND
   ------------------------------------------------------------ */
.bg-white{background-color:#fff}
.bg-white\/10{background-color:rgb(255 255 255/.1)}
.bg-white\/30{background-color:rgb(255 255 255/.3)}
.bg-white\/95{background-color:rgb(255 255 255/.95)}
.bg-black{background-color:#000}
.bg-black\/25{background-color:rgb(0 0 0/.25)}
.bg-black\/30{background-color:rgb(0 0 0/.3)}
.bg-black\/50{background-color:rgb(0 0 0/.5)}
.bg-black\/55{background-color:rgb(0 0 0/.55)}
.bg-black\/60{background-color:rgb(0 0 0/.6)}
.bg-slate-50{background-color:#f8fafc}
.bg-slate-100{background-color:#f1f5f9}
.bg-slate-200{background-color:#e2e8f0}
.bg-slate-200\/50{background-color:rgb(226 232 240/.5)}
.bg-slate-200\/70{background-color:rgb(226 232 240/.7)}
.bg-slate-300{background-color:#cbd5e1}
.bg-slate-900{background-color:#0f172a}
.bg-slate-900\/60{background-color:rgb(15 23 42/.6)}
.bg-slate-950{background-color:#020617}
.bg-rose-50{background-color:#fff1f2}
.bg-rose-100{background-color:#ffe4e6}
.bg-rose-500{background-color:#f43f5e}
.bg-rose-600{background-color:#e11d48}
.bg-amber-50{background-color:#fffbeb}
.bg-amber-100{background-color:#fef3c7}
.bg-amber-500{background-color:#f59e0b}
.bg-amber-600{background-color:#d97706}
.bg-emerald-50{background-color:#ecfdf5}
.bg-emerald-100{background-color:#d1fae5}
.bg-emerald-500{background-color:#10b981}
.bg-emerald-600{background-color:#059669}
.bg-indigo-50{background-color:#eef2ff}
.bg-indigo-100{background-color:#e0e7ff}
.bg-indigo-600{background-color:#4f46e5}
.bg-sky-50{background-color:#f0f9ff}
.bg-sky-100{background-color:#e0f2fe}
.bg-violet-600{background-color:#7c3aed}
.bg-purple-100{background-color:#f3e8ff}
.bg-gray-300{background-color:#d1d5db}
.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}
.from-amber-500{--tw-gradient-from:#f59e0b;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to,rgb(245 158 11/0))}
.to-orange-500{--tw-gradient-to:#f97316}

/* ------------------------------------------------------------
   BORDERS
   ------------------------------------------------------------ */
.border{border-width:1px}
.border-2{border-width:2px}
.border-t{border-top-width:1px}
.border-b{border-bottom-width:1px}
.border-b-2{border-bottom-width:2px}
.border-transparent{border-color:transparent}
.border-white{border-color:#fff}
.border-white\/10{border-color:rgb(255 255 255/.1)}
.border-white\/20{border-color:rgb(255 255 255/.2)}
.border-white\/30{border-color:rgb(255 255 255/.3)}
.border-white\/85{border-color:rgb(255 255 255/.85)}
.border-slate-100{border-color:#f1f5f9}
.border-slate-200{border-color:#e2e8f0}
.border-slate-200\/70{border-color:rgb(226 232 240/.7)}
.border-rose-100{border-color:#ffe4e6}
.border-rose-200{border-color:#fecdd3}
.border-rose-600{border-color:#e11d48}
.border-amber-200{border-color:#fde68a}
.border-emerald-200{border-color:#a7f3d0}
.border-indigo-100{border-color:#e0e7ff}
.border-indigo-200{border-color:#c7d2fe}
.border-indigo-600{border-color:#4f46e5}
.border-sky-200{border-color:#bae6fd}
.rounded{border-radius:.25rem}
.rounded-lg{border-radius:.5rem}
.rounded-xl{border-radius:.75rem}
.rounded-2xl{border-radius:1rem}
.rounded-3xl{border-radius:1.5rem}
.rounded-full{border-radius:9999px}
.rounded-t-xl{border-top-left-radius:.75rem;border-top-right-radius:.75rem}
.rounded-t-\[40px\]{border-top-left-radius:40px;border-top-right-radius:40px}
.rounded-\[24px\]{border-radius:24px}
.rounded-\[40px\]{border-radius:40px}
.last\:border-0:last-child{border-width:0}

/* ------------------------------------------------------------
   DIVIDE
   ------------------------------------------------------------ */
.divide-y>:not([hidden])~:not([hidden]){border-top-width:1px}
.divide-slate-50>:not([hidden])~:not([hidden]){border-color:#f8fafc}
.divide-slate-100>:not([hidden])~:not([hidden]){border-color:#f1f5f9}

/* ------------------------------------------------------------
   SPACE BETWEEN
   ------------------------------------------------------------ */
.space-x-4>:not([hidden])~:not([hidden]){margin-left:1rem}
.space-y-0\.5>:not([hidden])~:not([hidden]){margin-top:.125rem}
.space-y-1>:not([hidden])~:not([hidden]){margin-top:.25rem}
.space-y-2>:not([hidden])~:not([hidden]){margin-top:.5rem}
.space-y-3>:not([hidden])~:not([hidden]){margin-top:.75rem}
.space-y-4>:not([hidden])~:not([hidden]){margin-top:1rem}
.space-y-6>:not([hidden])~:not([hidden]){margin-top:1.5rem}

/* ------------------------------------------------------------
   SHADOWS
   ------------------------------------------------------------ */
.shadow{box-shadow:0 1px 3px 0 rgb(0 0 0/.1),0 1px 2px -1px rgb(0 0 0/.1)}
.shadow-sm{box-shadow:0 1px 2px 0 rgb(0 0 0/.05)}
.shadow-md{box-shadow:0 4px 6px -1px rgb(0 0 0/.1),0 2px 4px -2px rgb(0 0 0/.1)}
.shadow-lg{box-shadow:0 10px 15px -3px rgb(0 0 0/.1),0 4px 6px -4px rgb(0 0 0/.1)}
.shadow-xl{box-shadow:0 20px 25px -5px rgb(0 0 0/.1),0 8px 10px -6px rgb(0 0 0/.1)}
.shadow-2xl{box-shadow:0 25px 50px -12px rgb(0 0 0/.25)}
.shadow-inner{box-shadow:inset 0 2px 4px 0 rgb(0 0 0/.05)}
.shadow-indigo-200{box-shadow:0 4px 6px -1px #c7d2fe,0 2px 4px -2px #c7d2fe}
.shadow-rose-200{box-shadow:0 4px 6px -1px #fecdd3,0 2px 4px -2px #fecdd3}
.shadow-slate-200{box-shadow:0 4px 6px -1px #e2e8f0,0 2px 4px -2px #e2e8f0}
.shadow-slate-300{box-shadow:0 4px 6px -1px #cbd5e1,0 2px 4px -2px #cbd5e1}
.shadow-\[0_0_0_999px_rgba\(0\,0\,0\,0\.35\)\]{box-shadow:0 0 0 999px rgba(0,0,0,.35)}

/* ------------------------------------------------------------
   OVERFLOW / VISIBILITY / MISC
   ------------------------------------------------------------ */
.overflow-hidden{overflow:hidden}
.overflow-auto{overflow:auto}
.overflow-x-auto{overflow-x:auto}
.overflow-x-hidden{overflow-x:hidden}
.overflow-y-auto{overflow-y:auto}
.pointer-events-none{pointer-events:none}
.pointer-events-auto{pointer-events:auto}
.select-none{user-select:none}
.resize-none{resize:none}
.outline-none{outline:2px solid transparent;outline-offset:2px}
.appearance-none{-webkit-appearance:none;appearance:none}
.cursor-pointer{cursor:pointer}
.object-contain{object-fit:contain}
.object-cover{object-fit:cover}

/* ------------------------------------------------------------
   OPACITY
   ------------------------------------------------------------ */
.opacity-25{opacity:.25}
.opacity-50{opacity:.5}
.opacity-60{opacity:.6}
.opacity-70{opacity:.7}
.opacity-75{opacity:.75}
.opacity-80{opacity:.8}
.bg-opacity-20{--tw-bg-opacity:.2}

/* ------------------------------------------------------------
   Z-INDEX
   ------------------------------------------------------------ */
.z-10{z-index:10}
.z-20{z-index:20}
.z-30{z-index:30}
.z-40{z-index:40}
.z-50{z-index:50}
.z-\[20\]{z-index:20}
.z-\[80\]{z-index:80}
.z-\[100\]{z-index:100}
.z-\[200\]{z-index:200}
.z-\[9999\]{z-index:9999}

/* ------------------------------------------------------------
   TRANSFORMS
   ------------------------------------------------------------ */
.-translate-x-1\/2{transform:translateX(-50%)}
.-translate-y-1\/2{transform:translateY(-50%)}
.translate-x-full{transform:translateX(100%)}
.rotate-180{transform:rotate(180deg)}
.scale-95{transform:scale(.95)}
.scale-\[0\.98\]{transform:scale(.98)}
.scale-\[0\.99\]{transform:scale(.99)}

/* ------------------------------------------------------------
   TRANSITIONS
   ------------------------------------------------------------ */
.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(.4,0,.2,1);transition-duration:150ms}
.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.transition-colors{transition-property:color,background-color,border-color;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.duration-300{transition-duration:300ms}
.duration-500{transition-duration:500ms}
.ease-\[cubic-bezier\(0\.4\,0\,0\.2\,1\)\]{transition-timing-function:cubic-bezier(.4,0,.2,1)}

/* ------------------------------------------------------------
   BACKDROP
   ------------------------------------------------------------ */
.backdrop-blur{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
.backdrop-blur-sm{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}

/* ------------------------------------------------------------
   RING (focus rings)
   ------------------------------------------------------------ */
:root{--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000}
.focus\:ring-2:focus{--tw-ring-shadow:0 0 0 2px var(--tw-ring-color,#3b82f6);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}
.focus\:ring-4:focus{--tw-ring-shadow:0 0 0 4px var(--tw-ring-color,#3b82f6);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}
.focus\:ring-indigo-100:focus{--tw-ring-color:#e0e7ff}
.focus\:ring-indigo-200:focus{--tw-ring-color:#c7d2fe}
.focus\:ring-indigo-300:focus{--tw-ring-color:#a5b4fc}
.focus\:ring-indigo-500\/10:focus{--tw-ring-color:rgb(99 102 241/.1)}
.focus\:ring-violet-300:focus{--tw-ring-color:#c4b5fd}
.peer-focus\:ring-2:focus~.peer-focus\:ring-2{--tw-ring-shadow:0 0 0 2px var(--tw-ring-color,#c4b5fd);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}

/* ------------------------------------------------------------
   HOVER STATES
   ------------------------------------------------------------ */
.hover\:bg-white\/10:hover{background-color:rgb(255 255 255/.1)}
.hover\:bg-black\/70:hover{background-color:rgb(0 0 0/.7)}
.hover\:bg-slate-50:hover{background-color:#f8fafc}
.hover\:bg-slate-50\/50:hover{background-color:rgb(248 250 252/.5)}
.hover\:bg-slate-100:hover{background-color:#f1f5f9}
.hover\:bg-slate-200:hover{background-color:#e2e8f0}
.hover\:bg-slate-300:hover{background-color:#cbd5e1}
.hover\:bg-slate-800:hover{background-color:#1e293b}
.hover\:bg-rose-50:hover{background-color:#fff1f2}
.hover\:bg-rose-100:hover{background-color:#ffe4e6}
.hover\:bg-amber-100:hover{background-color:#fef3c7}
.hover\:bg-amber-200:hover{background-color:#fde68a}
.hover\:bg-amber-600:hover{background-color:#d97706}
.hover\:bg-amber-700:hover{background-color:#b45309}
.hover\:bg-emerald-50:hover{background-color:#ecfdf5}
.hover\:bg-emerald-700:hover{background-color:#047857}
.hover\:bg-indigo-50:hover{background-color:#eef2ff}
.hover\:bg-indigo-700:hover{background-color:#4338ca}
.hover\:bg-sky-200:hover{background-color:#bae6fd}
.hover\:text-slate-800:hover{color:#1e293b}
.hover\:text-slate-900:hover{color:#0f172a}
.hover\:text-white\/80:hover{color:rgb(255 255 255/.8)}
.hover\:underline:hover{text-decoration-line:underline}
.hover\:shadow-md:hover{box-shadow:0 4px 6px -1px rgb(0 0 0/.1),0 2px 4px -2px rgb(0 0 0/.1)}
.hover\:border-indigo-300:hover{border-color:#a5b4fc}

/* ------------------------------------------------------------
   FOCUS STATES
   ------------------------------------------------------------ */
.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}
.focus\:border-indigo-400:focus{border-color:#818cf8}
.focus\:border-indigo-500:focus{border-color:#6366f1}
.focus\:bg-white:focus{background-color:#fff}

/* ------------------------------------------------------------
   ACTIVE STATES
   ------------------------------------------------------------ */
.active\:scale-95:active{transform:scale(.95)}
.active\:scale-\[0\.98\]:active{transform:scale(.98)}
.active\:scale-\[0\.99\]:active{transform:scale(.99)}
.active\:rotate-180:active{transform:rotate(180deg)}
.active\:bg-black\/80:active{background-color:rgb(0 0 0/.8)}
.active\:bg-slate-100:active{background-color:#f1f5f9}
.active\:bg-slate-400:active{background-color:#94a3b8}
.active\:bg-slate-950:active{background-color:#020617}
.active\:bg-amber-200:active{background-color:#fde68a}
.active\:bg-amber-300:active{background-color:#fcd34d}
.active\:bg-amber-700:active{background-color:#b45309}
.active\:bg-amber-800:active{background-color:#92400e}
.active\:bg-emerald-100:active{background-color:#d1fae5}
.active\:bg-emerald-800:active{background-color:#065f46}
.active\:bg-indigo-800:active{background-color:#3730a3}
.active\:bg-sky-300:active{background-color:#7dd3fc}

/* ------------------------------------------------------------
   DISABLED STATES
   ------------------------------------------------------------ */
.disabled\:opacity-30:disabled{opacity:.3}
.disabled\:opacity-40:disabled{opacity:.4}
.disabled\:opacity-50:disabled{opacity:.5}
.disabled\:bg-slate-200:disabled{background-color:#e2e8f0}
.disabled\:text-slate-400:disabled{color:#94a3b8}
.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}
.disabled\:shadow-none:disabled{box-shadow:none}

/* ------------------------------------------------------------
   GROUP HOVER
   ------------------------------------------------------------ */
.group:hover .group-hover\:text-slate-500{color:#64748b}

/* ------------------------------------------------------------
   PEER — toggle switch
   ------------------------------------------------------------ */
.peer:checked~.peer-checked\:bg-violet-600{background-color:#7c3aed}
.peer:checked~.peer-checked\:after\:translate-x-full::after{transform:translateX(100%)}

/* ------------------------------------------------------------
   AFTER PSEUDO — toggle switch thumb
   ------------------------------------------------------------ */
.after\:absolute::after{content:var(--tw-content,'');position:absolute}
.after\:content-\[\''\]\::after{--tw-content:'';content:var(--tw-content,'')}
.after\:top-\[2px\]::after{top:2px}
.after\:left-\[2px\]::after{left:2px}
.after\:h-5::after{height:1.25rem}
.after\:w-5::after{width:1.25rem}
.after\:rounded-full::after{border-radius:9999px}
.after\:bg-white::after{background-color:#fff}
.after\:transition-all::after{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}

/* ------------------------------------------------------------
   RESPONSIVE — sm (640px)
   ------------------------------------------------------------ */
@media(min-width:640px){
  .sm\:-mx-5{margin-left:-1.25rem;margin-right:-1.25rem}
  .sm\:col-span-2{grid-column:span 2/span 2}
  .sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .sm\:hidden{display:none}
  .sm\:inset-x-\[20\%\]{left:20%;right:20%}
  .sm\:items-center{align-items:center}
  .sm\:p-6{padding:1.5rem}
  .sm\:px-5{padding-left:1.25rem;padding-right:1.25rem}
  .sm\:rounded-\[40px\]{border-radius:40px}
  .sm\:top-14{top:3.5rem}
  .sm\:w-auto{width:auto}
}

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

/* ------------------------------------------------------------
   RESPONSIVE — lg (1024px)
   ------------------------------------------------------------ */
@media(min-width:1024px){
  .lg\:block{display:block}
  .lg\:flex{display:flex}
  .lg\:flex-1{flex:1 1 0%}
  .lg\:flex-col{flex-direction:column}
  .lg\:gap-4{gap:1rem}
  .lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
  .lg\:h-\[calc\(100vh-70px\)\]{height:calc(100vh - 70px)}
  .lg\:hidden{display:none}
  .lg\:min-h-0{min-height:0}
  .lg\:min-w-0{min-width:0}
  .lg\:mt-0{margin-top:0}
  .lg\:overflow-hidden{overflow:hidden}
  .lg\:overflow-y-auto{overflow-y:auto}
  .lg\:shrink-0{flex-shrink:0}
  .lg\:w-\[340px\]{width:340px}
}

/* ═══════════════════════════════════════════════════════════
   OFFLINE CSS ADDITIONS — auto-generated from class scan
   ═══════════════════════════════════════════════════════════ */

/* Opacity modifiers */
.bg-black\/25{background-color:rgb(0 0 0/0.25)}
.bg-black\/30{background-color:rgb(0 0 0/0.30)}
.bg-black\/40{background-color:rgb(0 0 0/0.40)}
.bg-black\/50{background-color:rgb(0 0 0/0.50)}
.bg-black\/55{background-color:rgb(0 0 0/0.55)}
.bg-black\/60{background-color:rgb(0 0 0/0.60)}
.bg-slate-200\/50{background-color:rgb(226 232 240/0.50)}
.bg-slate-200\/70{background-color:rgb(226 232 240/0.70)}
.bg-slate-600{background-color:#475569}
.bg-slate-900\/60{background-color:rgb(15 23 42/0.60)}
.bg-white\/10{background-color:rgb(255 255 255/0.10)}
.bg-white\/20{background-color:rgb(255 255 255/0.20)}
.bg-white\/95{background-color:rgb(255 255 255/0.95)}

/* Border opacity/color */
.border-dashed{border-style:dashed}
.border-slate-200\/70{border-color:rgb(226 232 240/0.70)}
.border-slate-300{border-color:#cbd5e1}
.border-white\/10{border-color:rgb(255 255 255/0.10)}
.border-white\/30{border-color:rgb(255 255 255/0.30)}
.border-white\/50{border-color:rgb(255 255 255/0.50)}
.border-white\/85{border-color:rgb(255 255 255/0.85)}

/* Text colors */
.text-blue-600{color:#2563eb}
.text-gray-500{color:#6b7280}
.text-red-600{color:#dc2626}
.text-white\/80{color:rgb(255 255 255/0.80)}
.text-\[9px\]{font-size:9px;line-height:1.4}
.text-\[10px\]{font-size:10px;line-height:1.4}
.text-\[11px\]{font-size:11px;line-height:1.5}
.text-\[12px\]{font-size:12px;line-height:1.5}

/* Font */
.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}

/* Opacity */
.opacity-0{opacity:0}

/* Spacing — gaps */
.gap-1\.5{gap:0.375rem}
.gap-5{gap:1.25rem}
.space-x-2>*+*{margin-left:0.5rem}
.space-y-0\.5>*+*{margin-top:0.125rem}

/* Spacing — padding */
.p-1\.5{padding:0.375rem}
.px-1\.5{padding-left:0.375rem;padding-right:0.375rem}
.py-0\.5{padding-top:0.125rem;padding-bottom:0.125rem}
.py-1\.5{padding-top:0.375rem;padding-bottom:0.375rem}
.py-2\.5{padding-top:0.625rem;padding-bottom:0.625rem}
.py-10{padding-top:2.5rem;padding-bottom:2.5rem}
.pb-32{padding-bottom:8rem}
.pb-\[env\(safe-area-inset-bottom\)\]{padding-bottom:env(safe-area-inset-bottom)}
.pl-4{padding-left:1rem}

/* Spacing — margin */
.mb-0\.5{margin-bottom:0.125rem}
.mt-0\.5{margin-top:0.125rem}

/* Sizing — width */
.w-1\/2{width:50%}
.w-20{width:5rem}
.w-36{width:9rem}
.w-\[420px\]{width:420px}
.w-\[86\%\]{width:86%}
.min-w-max{min-width:max-content}
.min-w-\[1\.2rem\]{min-width:1.2rem}
.min-w-\[1\.6rem\]{min-width:1.6rem}
.min-w-\[20px\]{min-width:20px}
.min-w-\[40px\]{min-width:40px}
.min-w-\[44px\]{min-width:44px}
.min-w-\[260px\]{min-width:260px}

/* Sizing — height */
.h-3{height:0.75rem}
.h-36{height:9rem}
.min-h-\[1\.2em\]{min-height:1.2em}

/* Sizing — max */
.max-w-\[360px\]{max-width:360px}
.max-w-\[760px\]{max-width:760px}
.max-w-\[980px\]{max-width:980px}
.max-w-\[80vw\]{max-width:80vw}
.max-w-\[85\%\]{max-width:85%}
.max-w-\[90vw\]{max-width:90vw}
.max-h-\[280px\]{max-height:280px}
.max-h-\[60vh\]{max-height:60vh}
.max-h-\[80vh\]{max-height:80vh}
.max-h-\[90vh\]{max-height:90vh}

/* Aspect ratio */
.aspect-\[4\/3\]{aspect-ratio:4/3}
.aspect-\[1\.585\/1\]{aspect-ratio:1.585/1}

/* Rounded */
.rounded-t-3xl{border-top-left-radius:1.5rem;border-top-right-radius:1.5rem}
.rounded-\[24px\]{border-radius:24px}
.rounded-\[40px\]{border-radius:40px}
.rounded-t-\[40px\]{border-top-left-radius:40px;border-top-right-radius:40px}

/* Shadow */
.shadow-emerald-200{--tw-shadow-color:#a7f3d0;box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),0 4px 6px -1px var(--tw-shadow-color)}
.shadow-\[0_0_0_999px_rgba\(0\,0\,0\,0\.35\)\]{box-shadow:0 0 0 999px rgba(0,0,0,0.35)}

/* Positioning */
.bottom-24{bottom:6rem}
.bottom-\[90px\]{bottom:90px}
.top-3{top:0.75rem}
.top-0\.5{top:0.125rem}
.top-1\/2{top:50%}
.top-\[10px\]{top:10px}
.top-\[52px\]{top:52px}
.left-0\.5{left:0.125rem}
.left-1\/2{left:50%}

/* Z-index */
.z-\[20\]{z-index:20}
.z-\[80\]{z-index:80}
.z-\[100\]{z-index:100}
.z-\[200\]{z-index:200}
.z-\[9997\]{z-index:9997}
.z-\[9998\]{z-index:9998}
.z-\[9999\]{z-index:9999}

/* ── Toggle (peer-checked) additions ───────────────────────────── */
.peer:checked~.peer-checked\:bg-indigo-600{background-color:#4f46e5}
.peer:checked~.peer-checked\:bg-emerald-600{background-color:#059669}
.peer:checked~.peer-checked\:bg-sky-600{background-color:#0284c7}
.peer:checked~.peer-checked\:bg-rose-600{background-color:#e11d48}
.peer:checked~.peer-checked\:bg-amber-600{background-color:#d97706}
.peer:checked~.peer-checked\:bg-teal-600{background-color:#0d9488}
.peer:checked~.peer-checked\:bg-orange-600{background-color:#ea580c}
.peer:checked~.peer-checked\:bg-pink-600{background-color:#db2777}
.peer:checked~.peer-checked\:after\:translate-x-5::after{transform:translateX(1.25rem)}
.peer:checked~.peer-checked\:after\:translate-x-full::after{--tw-translate-x:100%;transform:translateX(var(--tw-translate-x))}
.after\:absolute::after{position:absolute}
.after\:top-0\.5::after{top:0.125rem}
.after\:left-0\.5::after{left:0.125rem}
.after\:top-\[2px\]::after{top:2px}
.after\:left-\[2px\]::after{left:2px}
.after\:h-4::after{height:1rem}
.after\:w-4::after{width:1rem}
.after\:h-5::after{height:1.25rem}
.after\:w-5::after{width:1.25rem}
.after\:rounded-full::after{border-radius:9999px}
.after\:bg-white::after{background-color:#fff}
.after\:transition-all::after{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.after\:content-\[\''\'\]::after{content:''}
