:root {
  --socium-navy: #0b2945;
  --socium-blue: #1976b9;
  --socium-cyan: #39b7c7;
  --socium-mist: #eef5fb;
  --socium-border: #d7e2ec;
  --socium-muted: #5f7183;
}

* { box-sizing: border-box; }
body { margin: 0; background: #f1f5f9; color: var(--socium-navy); font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
table { border-collapse: collapse; width: 100%; }
th, td { padding: .8rem 1rem; text-align: left; vertical-align: middle; }
thead { background: var(--socium-mist); color: #475569; font-size: .75rem; font-weight: 900; text-transform: uppercase; }
tbody tr { border-top: 1px solid #e2e8f0; }

.socium-shell { min-height: 100vh; background: #f1f5f9; }
.socium-sidebar { background: var(--socium-navy); bottom: 0; color: #fff; display: none; left: 0; padding: 1.25rem; position: fixed; top: 0; width: 18rem; z-index: 40; }
.socium-sidebar nav { display: grid; gap: .25rem; }
.socium-sidebar a { border-radius: .45rem; color: rgba(255,255,255,.86); display: block; font-size: .92rem; font-weight: 750; padding: .65rem .75rem; }
.socium-sidebar a:hover { background: rgba(255,255,255,.1); color: #fff; }
.socium-main { min-height: 100vh; }
.socium-topbar { background: rgba(255,255,255,.96); border-bottom: 1px solid var(--socium-border); padding: .75rem 1rem; position: sticky; top: 0; z-index: 30; }
.socium-page { margin: 0 auto; max-width: 1500px; padding: 1.5rem 1rem; }
.socium-panel { background: #fff; border: 1px solid var(--socium-border); border-radius: .55rem; box-shadow: 0 16px 40px rgba(11,41,69,.08); padding: 1.25rem; }
.socium-button, .socium-button-secondary { align-items: center; border-radius: .45rem; cursor: pointer; display: inline-flex; font-size: .9rem; font-weight: 800; gap: .5rem; justify-content: center; padding: .58rem 1rem; transition: .16s ease; }
.socium-button { background: var(--socium-blue); border: 1px solid var(--socium-blue); color: #fff; }
.socium-button:hover { background: var(--socium-navy); }
.socium-button-secondary { background: #fff; border: 1px solid #cbd5e1; color: var(--socium-navy); }
.socium-button-secondary:hover { border-color: var(--socium-blue); color: var(--socium-blue); }
.socium-field { border: 1px solid #cbd5e1; border-radius: .45rem; box-shadow: 0 1px 2px rgba(15,23,42,.04); color: var(--socium-navy); min-height: 2.55rem; padding: .55rem .7rem; width: 100%; }
.socium-label { color: var(--socium-muted); display: block; font-size: .72rem; font-weight: 900; letter-spacing: .04em; text-transform: uppercase; }

.min-h-screen { min-height: 100vh; }
.grid { display: grid; }
.flex { display: flex; }
.hidden { display: none; }
.block { display: block; }
.inline-flex { display: inline-flex; }
.place-items-center { place-items: center; }
.items-center { align-items: center; }
.items-end { align-items: flex-end; }
.justify-between { justify-content: space-between; }
.justify-center { justify-content: center; }
.flex-col { flex-direction: column; }
.flex-wrap { flex-wrap: wrap; }
.gap-2 { gap: .5rem; }
.gap-3 { gap: .75rem; }
.gap-4 { gap: 1rem; }
.space-y-1 > * + * { margin-top: .25rem; }
.space-y-4 > * + * { margin-top: 1rem; }
.space-y-6 > * + * { margin-top: 1.5rem; }
.mx-auto { margin-left: auto; margin-right: auto; }
.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: .25rem; }
.mb-4 { margin-bottom: 1rem; }
.mb-8 { margin-bottom: 2rem; }
.mt-1 { margin-top: .25rem; }
.mt-3 { margin-top: .75rem; }
.mt-4 { margin-top: 1rem; }
.mt-6 { margin-top: 1.5rem; }
.w-full { width: 100%; }
.w-20 { width: 5rem; }
.h-32 { height: 8rem; }
.h-full { height: 100%; }
.max-w-md { max-width: 28rem; }
.max-w-\\[1500px\\] { max-width: 1500px; }
.overflow-hidden { overflow: hidden; }
.overflow-x-auto { overflow-x: auto; }
.rounded, .rounded-md { border-radius: .45rem; }
.rounded-lg { border-radius: .55rem; }
.rounded-full { border-radius: 999px; }
.rounded-t { border-top-left-radius: .35rem; border-top-right-radius: .35rem; }
.border { border: 1px solid var(--socium-border); }
.border-t-4 { border-top-width: 4px; }
.border-t-socium-blue { border-top-color: var(--socium-blue); }
.bg-white { background: #fff; }
.bg-slate-100 { background: #f1f5f9; }
.bg-slate-50 { background: #f8fafc; }
.bg-orange-50 { background: #fff7ed; }
.bg-emerald-50 { background: #ecfdf5; }
.bg-amber-50 { background: #fffbeb; }
.bg-red-50 { background: #fef2f2; }
.bg-socium-mist { background: var(--socium-mist); }
.from-socium-blue { --from: var(--socium-blue); }
.to-socium-cyan { --to: var(--socium-cyan); }
.bg-gradient-to-t { background: linear-gradient(to top, var(--from), var(--to)); }
.text-socium-navy { color: var(--socium-navy); }
.text-socium-blue { color: var(--socium-blue); }
.text-slate-500 { color: #64748b; }
.text-slate-600 { color: #475569; }
.text-emerald-700 { color: #047857; }
.text-amber-700 { color: #b45309; }
.text-red-600, .text-red-700 { color: #dc2626; }
.text-sm { font-size: .875rem; }
.text-xs { font-size: .75rem; }
.text-lg { font-size: 1.125rem; }
.text-xl { font-size: 1.25rem; }
.text-2xl { font-size: 1.5rem; }
.text-3xl { font-size: 1.875rem; }
.font-bold { font-weight: 700; }
.font-black { font-weight: 900; }
.font-semibold { font-weight: 700; }
.uppercase { text-transform: uppercase; }
.divide-y > * + * { border-top: 1px solid #e2e8f0; }
.min-w-full { min-width: 100%; }
.p-0 { padding: 0; }
.p-3 { padding: .75rem; }
.p-4 { padding: 1rem; }
.p-5 { padding: 1.25rem; }
.p-8 { padding: 2rem; }
.px-2, .px-2\\.5 { padding-left: .625rem; padding-right: .625rem; }
.px-3 { padding-left: .75rem; padding-right: .75rem; }
.px-4 { padding-left: 1rem; padding-right: 1rem; }
.py-1 { padding-bottom: .25rem; padding-top: .25rem; }
.py-2 { padding-bottom: .5rem; padding-top: .5rem; }
.py-3 { padding-bottom: .75rem; padding-top: .75rem; }
.text-left { text-align: left; }
.text-right { text-align: right; }
.shadow-panel { box-shadow: 0 16px 40px rgba(11,41,69,.08); }

@media (min-width: 640px) {
  .sm\\:block { display: block; }
  .sm\\:flex-row { flex-direction: row; }
  .sm\\:items-end { align-items: flex-end; }
}

@media (min-width: 768px) {
  .md\\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .md\\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .md\\:col-span-3 { grid-column: span 3 / span 3; }
}

@media (min-width: 1024px) {
  .lg\\:block { display: block; }
  .lg\\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .socium-sidebar { display: block; }
  .socium-main { padding-left: 18rem; }
  .socium-page { padding-left: 2rem; padding-right: 2rem; }
}

@media (min-width: 1280px) {
  .xl\\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .xl\\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .xl\\:col-span-2 { grid-column: span 2 / span 2; }
}
