/*
 * Spectranox SOC - locally hosted utility CSS (Tailwind-compatible subset)
 * Pre-built so production never needs the Tailwind CDN.
 *
 * For full Tailwind, run:
 *   npx tailwindcss -i tailwind.in.css -o public/assets/css/app.css --minify
 * (a tailwind.config.js is included in docs/).
 *
 * This file ships a hand-curated subset that powers every utility class used
 * across views/. Replace freely with a full Tailwind build if desired.
 */

*,::before,::after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#1e293b}
html,body{margin:0;padding:0;line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}
body{font-feature-settings:normal;text-rendering:optimizeLegibility}
h1,h2,h3,h4,h5,h6,p,pre,table,ul,ol,figure,blockquote{margin:0}
a{color:inherit;text-decoration:inherit}
img,svg,video,canvas{display:block;max-width:100%;height:auto}
input,button,textarea,select{font:inherit;color:inherit;background:transparent;border:0;padding:0}
button{cursor:pointer}
pre,code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace}
table{border-collapse:collapse;border-spacing:0}

/* Color palette (slate + accents) */
:root{
  --c-slate-50:#f8fafc;--c-slate-100:#f1f5f9;--c-slate-200:#e2e8f0;--c-slate-300:#cbd5e1;
  --c-slate-400:#94a3b8;--c-slate-500:#64748b;--c-slate-600:#475569;--c-slate-700:#334155;
  --c-slate-800:#1e293b;--c-slate-900:#0f172a;--c-slate-950:#020617;
  --c-cyan-300:#67e8f9;--c-cyan-400:#22d3ee;--c-cyan-500:#06b6d4;
  --c-amber-300:#fcd34d;--c-amber-400:#fbbf24;--c-amber-500:#f59e0b;
  --c-rose-300:#fda4af;--c-rose-400:#fb7185;--c-rose-500:#f43f5e;
  --c-emerald-300:#6ee7b7;--c-emerald-400:#34d399;--c-emerald-500:#10b981;
  --c-fuchsia-300:#f0abfc;--c-fuchsia-400:#e879f9;--c-fuchsia-500:#d946ef;
  --c-yellow-300:#fde047;--c-yellow-400:#facc15;
  --c-sky-300:#7dd3fc;
}

/* layout */
.flex{display:flex}.grid{display:grid}.inline-block{display:inline-block}.block{display:block}.hidden{display:none}
.flex-1{flex:1 1 0%}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}
.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-baseline{align-items:baseline}
.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}
.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}
.space-y-1>:not([hidden])~:not([hidden]){margin-top:.25rem}.space-y-1\.5>:not([hidden])~:not([hidden]){margin-top:.375rem}
.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-5>:not([hidden])~:not([hidden]){margin-top:1.25rem}
.space-y-6>:not([hidden])~:not([hidden]){margin-top:1.5rem}
.divide-y>:not([hidden])~:not([hidden]){border-top-width:1px}
.divide-slate-800>*{border-color:var(--c-slate-800)}
.divide-slate-800\/60>*{border-color:rgba(30,41,59,.6)}
.min-h-screen{min-height:100vh}.h-full{height:100%}.h-screen{height:100vh}.h-14{height:3.5rem}.h-9{height:2.25rem}.h-10{height:2.5rem}.h-28{height:7rem}.h-72{height:18rem}.max-h-72{max-height:18rem}.max-h-96{max-height:24rem}
.w-full{width:100%}.w-60{width:15rem}.w-80{width:20rem}.w-9{width:2.25rem}.w-10{width:2.5rem}.w-12{width:3rem}.w-28{width:7rem}.w-1\.5{width:.375rem}.w-3{width:.75rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}
.min-w-0{min-width:0}.max-w-md{max-width:28rem}.max-w-xs{max-width:20rem}.max-w-sm{max-width:24rem}.max-w-2xl{max-width:42rem}.max-w-7xl{max-width:80rem}
.mx-auto{margin-left:auto;margin-right:auto}.ml-auto{margin-left:auto}
.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}
.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}
.pt-2{padding-top:.5rem}.pt-4{padding-top:1rem}.pr-2{padding-right:.5rem}.pr-4{padding-right:1rem}.pb-1\.5{padding-bottom:.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}
.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-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}
.pl-3{padding-left:.75rem}.pl-10{padding-left:2.5rem}.pr-3{padding-right:.75rem}
.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}
.inset-0{inset:0}.top-0{top:0}.left-3{left:.75rem}.top-1\/2{top:50%}
.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.whitespace-pre-wrap{white-space:pre-wrap}
.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}
.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}
.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-extrabold{font-weight:800}.font-black{font-weight:900}
.uppercase{text-transform:uppercase}.tracking-tight{letter-spacing:-.025em}.tracking-widest{letter-spacing:.1em}
.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[9px\]{font-size:9px}
.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-6xl{font-size:3.75rem;line-height:1}
.rounded{border-radius:.25rem}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.rounded-full{border-radius:9999px}
.border{border-width:1px}.border-0{border-width:0}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-r{border-right-width:1px}
.cursor-pointer{cursor:pointer}.select-none{user-select:none}
.transition{transition:all .2s ease}.transition-colors{transition:color .2s ease,background-color .2s ease,border-color .2s ease}
.opacity-20{opacity:.2}
.shadow-md{box-shadow:0 4px 6px -1px rgba(0,0,0,.3),0 2px 4px -2px rgba(0,0,0,.3)}
.shadow-lg{box-shadow:0 10px 15px -3px rgba(0,0,0,.4),0 4px 6px -4px rgba(0,0,0,.4)}
.shadow-2xl{box-shadow:0 25px 50px -12px rgba(0,0,0,.5)}
.backdrop-blur{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.font-mono{font-variant-numeric:tabular-nums}

/* grid templates */
.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))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
@media(min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:flex-row{flex-direction:row}.md\:items-center{align-items:center}.md\:p-6{padding:1.5rem}.md\:p-8{padding:2rem}.md\:w-64{width:16rem}.md\:flex-none{flex:none}.md\:hidden{display:none}.md\:block{display:block}}
@media(min-width:1280px){.xl\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.xl\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.xl\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.xl\:col-span-2{grid-column:span 2 / span 2}}

/* backgrounds & colors */
.bg-slate-950{background-color:var(--c-slate-950)}.bg-slate-900{background-color:var(--c-slate-900)}.bg-slate-900\/80{background-color:rgba(15,23,42,.8)}.bg-slate-900\/60{background-color:rgba(15,23,42,.6)}.bg-slate-900\/40{background-color:rgba(15,23,42,.4)}.bg-slate-800{background-color:var(--c-slate-800)}.bg-slate-800\/50{background-color:rgba(30,41,59,.5)}.bg-slate-800\/30{background-color:rgba(30,41,59,.3)}.bg-slate-800\/40{background-color:rgba(30,41,59,.4)}.bg-slate-700{background-color:var(--c-slate-700)}
.bg-cyan-500{background-color:var(--c-cyan-500)}.bg-cyan-500\/10{background-color:rgba(6,182,212,.1)}.bg-cyan-500\/20{background-color:rgba(6,182,212,.2)}.bg-cyan-500\/30{background-color:rgba(6,182,212,.3)}.hover\:bg-cyan-400:hover{background-color:var(--c-cyan-400)}
.bg-fuchsia-500{background-color:var(--c-fuchsia-500)}.bg-fuchsia-500\/10{background-color:rgba(217,70,239,.1)}.bg-fuchsia-500\/20{background-color:rgba(217,70,239,.2)}.bg-fuchsia-500\/30{background-color:rgba(217,70,239,.3)}.hover\:bg-fuchsia-400:hover{background-color:var(--c-fuchsia-400)}.hover\:bg-fuchsia-500\/30:hover{background-color:rgba(217,70,239,.3)}
.bg-amber-500\/20{background-color:rgba(245,158,11,.2)}.hover\:bg-amber-500\/30:hover{background-color:rgba(245,158,11,.3)}
.bg-rose-500\/20{background-color:rgba(244,63,94,.2)}.hover\:bg-rose-500\/30:hover{background-color:rgba(244,63,94,.3)}
.bg-emerald-500\/20{background-color:rgba(16,185,129,.2)}.hover\:bg-emerald-500\/30:hover{background-color:rgba(16,185,129,.3)}
.bg-yellow-500\/20{background-color:rgba(234,179,8,.2)}
.bg-sky-500\/20{background-color:rgba(14,165,233,.2)}
.bg-slate-500\/20{background-color:rgba(100,116,139,.2)}
.hover\:bg-slate-700:hover{background-color:var(--c-slate-700)}.hover\:bg-slate-800:hover{background-color:var(--c-slate-800)}
.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--from),var(--to))}
.from-cyan-500{--from:var(--c-cyan-500)}.to-fuchsia-500{--to:var(--c-fuchsia-500)}

.text-white{color:#fff}.text-slate-200{color:var(--c-slate-200)}.text-slate-300{color:var(--c-slate-300)}.text-slate-400{color:var(--c-slate-400)}.text-slate-500{color:var(--c-slate-500)}.text-slate-600{color:var(--c-slate-600)}.text-slate-700{color:var(--c-slate-700)}.text-slate-950{color:var(--c-slate-950)}
.text-cyan-300{color:var(--c-cyan-300)}.text-cyan-400{color:var(--c-cyan-400)}.text-rose-300{color:var(--c-rose-300)}.text-rose-400{color:var(--c-rose-400)}.text-amber-300{color:var(--c-amber-300)}.text-amber-400{color:var(--c-amber-400)}.text-yellow-300{color:var(--c-yellow-300)}.text-emerald-300{color:var(--c-emerald-300)}.text-emerald-400{color:var(--c-emerald-400)}.text-fuchsia-300{color:var(--c-fuchsia-300)}.text-fuchsia-400{color:var(--c-fuchsia-400)}.text-sky-300{color:var(--c-sky-300)}
.hover\:text-white:hover{color:#fff}.hover\:text-cyan-300:hover{color:var(--c-cyan-300)}.hover\:text-red-400:hover{color:#f87171}.hover\:border-cyan-500\/40:hover{border-color:rgba(6,182,212,.4)}

/* borders */
.border-slate-800{border-color:var(--c-slate-800)}.border-slate-700{border-color:var(--c-slate-700)}
.border-cyan-500\/20{border-color:rgba(6,182,212,.2)}.border-cyan-500\/30{border-color:rgba(6,182,212,.3)}
.border-fuchsia-500\/20{border-color:rgba(217,70,239,.2)}.border-fuchsia-500\/30{border-color:rgba(217,70,239,.3)}
.border-rose-500\/20{border-color:rgba(244,63,94,.2)}.border-rose-500\/30{border-color:rgba(244,63,94,.3)}
.border-amber-500\/20{border-color:rgba(245,158,11,.2)}.border-amber-500\/30{border-color:rgba(245,158,11,.3)}
.border-emerald-500\/20{border-color:rgba(16,185,129,.2)}.border-emerald-500\/30{border-color:rgba(16,185,129,.3)}
.border-yellow-500\/30{border-color:rgba(234,179,8,.3)}
.border-sky-500\/30{border-color:rgba(14,165,233,.3)}
.border-slate-500\/30{border-color:rgba(100,116,139,.3)}
.border-white\/5{border-color:rgba(255,255,255,.05)}

/* focus */
.focus\:outline-none:focus{outline:none}
.focus\:border-cyan-500:focus{border-color:var(--c-cyan-500)}
.focus\:ring-1:focus{box-shadow:0 0 0 1px var(--c-cyan-500)}

/* place-items */
.place-items-center{place-items:center}

/* animations */
@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s ease-in-out infinite}

/* scrollbar */
::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--c-slate-700);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--c-slate-600)}

/* glow */
.text-fuchsia-300,.text-cyan-300{text-shadow:0 0 12px currentColor}

/* ---- Supplemental utilities (were missing from the purged build; added so
   dots, spinners, rings, and small icons render correctly across all views) ---- */
.inline-flex{display:inline-flex}
.gap-1\.5{gap:.375rem}
.w-2\.5{width:.625rem}.h-2\.5{height:.625rem}
.w-3\.5{width:.875rem}.h-3\.5{height:.875rem}
.bg-emerald-400{background-color:#34d399}
.opacity-90{opacity:.9}.opacity-60{opacity:.6}
.pointer-events-none{pointer-events:none}
.object-fill{object-fit:fill}
.line-through{text-decoration-line:line-through}
.ring-2{box-shadow:0 0 0 2px rgba(255,255,255,.25)}
@keyframes ping{75%,100%{transform:scale(2);opacity:0}}
.animate-ping{animation:ping 1.4s cubic-bezier(0,0,.2,1) infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.animate-spin{animation:spin 1s linear infinite}
