/* ============================================================
   FRALIB OS — DESIGN SYSTEM v1.0
   Import em TODAS as páginas: <link rel="stylesheet" href="design-system.css">
   ============================================================ */
:root {
  --fl-bg:#060608;--fl-bg-surface:#0d0d12;--fl-bg-card:#12121a;
  --fl-bg-card-2:#18182280;--fl-bg-hover:#1c1c28;--fl-bg-overlay:rgba(6,6,8,0.92);
  --fl-purple-950:#0e0718;--fl-purple-900:#1a0a30;--fl-purple-800:#2d1060;
  --fl-purple-700:#4c1d9e;--fl-purple-600:#7c3aed;--fl-purple:#9333ea;
  --fl-purple-400:#a855f7;--fl-purple-300:#c084fc;--fl-purple-200:#d8b4fe;--fl-purple-100:#ede9fe;
  --fl-glow-xs:0 0 8px rgba(147,51,234,0.20);--fl-glow-sm:0 0 16px rgba(147,51,234,0.28);
  --fl-glow-md:0 0 32px rgba(147,51,234,0.35);--fl-glow-lg:0 0 60px rgba(147,51,234,0.45);
  --fl-border-glow:0 0 0 1px rgba(147,51,234,0.50);
  --fl-border:rgba(147,51,234,0.12);--fl-border-md:rgba(147,51,234,0.25);
  --fl-border-hi:rgba(147,51,234,0.50);--fl-border-solid:#9333ea;
  --fl-text:#f0f0f5;--fl-text-muted:#8888a0;--fl-text-dim:#44445a;
  --fl-text-brand:#c084fc;--fl-text-inv:#060608;
  --fl-success:#22c55e;--fl-success-bg:rgba(34,197,94,0.10);
  --fl-warning:#f59e0b;--fl-warning-bg:rgba(245,158,11,0.10);
  --fl-danger:#ef4444;--fl-danger-bg:rgba(239,68,68,0.10);
  --fl-info:#06b6d4;--fl-info-bg:rgba(6,182,212,0.10);
  --fl-font-brand:'Press Start 2P',monospace;--fl-font-ui:'DM Sans',system-ui,sans-serif;
  --fl-font-mono:'JetBrains Mono',monospace;
  --fl-r-xs:3px;--fl-r-sm:6px;--fl-r-md:10px;--fl-r-lg:14px;--fl-r-xl:20px;--fl-r-full:9999px;
  --fl-ease:cubic-bezier(0.22,1,0.36,1);
  --fl-t-fast:120ms cubic-bezier(0.22,1,0.36,1);
  --fl-t-med:220ms cubic-bezier(0.22,1,0.36,1);
  --fl-t-slow:380ms cubic-bezier(0.22,1,0.36,1);
  --cyan:#00FFB3;--cyan-dim:rgba(0,255,179,0.12);--cyan-glow:rgba(0,255,179,0.4);
  --gold:#FFB800;--gold-dim:rgba(255,184,0,0.15);--gold-glow:rgba(255,184,0,0.35);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fl-font-ui);background:var(--fl-bg);color:var(--fl-text);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--fl-bg)}
::-webkit-scrollbar-thumb{background:var(--fl-border-hi);border-radius:99px}
.fl-brand{font-family:var(--fl-font-brand)}.fl-mono{font-family:var(--fl-font-mono)}
.fl-display{font-family:var(--fl-font-brand);font-size:clamp(16px,3vw,28px);line-height:1.8;color:var(--fl-text)}
.fl-h1{font-family:var(--fl-font-brand);font-size:clamp(11px,2vw,18px);line-height:2;color:var(--fl-text)}
.fl-h2{font-family:var(--fl-font-brand);font-size:clamp(9px,1.5vw,13px);line-height:2;color:var(--fl-text)}
.fl-h3{font-family:var(--fl-font-brand);font-size:9px;line-height:2;color:var(--fl-text-muted);letter-spacing:0.05em;text-transform:uppercase}
.fl-body{font-size:15px;line-height:1.65;color:var(--fl-text)}
.fl-body-sm{font-size:13px;line-height:1.6;color:var(--fl-text-muted)}
.fl-caption{font-size:11px;line-height:1.5;color:var(--fl-text-dim);font-family:var(--fl-font-mono)}
.fl-accent{color:var(--fl-purple-300)}
.fl-glow-text{color:var(--fl-purple-300);text-shadow:0 0 10px rgba(192,132,252,0.8),0 0 30px rgba(147,51,234,0.5),0 0 60px rgba(147,51,234,0.3)}
.fl-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--fl-font-brand);font-size:8px;line-height:1;padding:14px 22px;border-radius:var(--fl-r-sm);border:1px solid transparent;cursor:pointer;text-decoration:none;transition:all var(--fl-t-fast);white-space:nowrap}
.fl-btn-primary{background:var(--fl-purple);color:#fff;border-color:var(--fl-purple);box-shadow:var(--fl-glow-sm)}
.fl-btn-primary:hover{background:var(--fl-purple-400);border-color:var(--fl-purple-400);box-shadow:var(--fl-glow-md);transform:translateY(-1px)}
.fl-btn-primary:active{transform:translateY(0)}
.fl-btn-outline{background:transparent;color:var(--fl-purple-300);border-color:var(--fl-border-md)}
.fl-btn-outline:hover{background:var(--fl-bg-hover);border-color:var(--fl-border-hi);box-shadow:var(--fl-glow-xs)}
.fl-btn-ghost{background:transparent;color:var(--fl-text-muted);border-color:transparent;font-family:var(--fl-font-ui);font-size:13px;font-weight:500;padding:10px 16px}
.fl-btn-ghost:hover{color:var(--fl-text);background:var(--fl-bg-hover)}
.fl-btn-danger{background:var(--fl-danger-bg);color:var(--fl-danger);border-color:rgba(239,68,68,0.25)}
.fl-btn-danger:hover{background:rgba(239,68,68,0.18)}
.fl-btn-sm{padding:10px 16px;font-size:7px}.fl-btn-lg{padding:18px 32px;font-size:10px}
.fl-btn-xs{padding:7px 12px;font-size:11px;font-family:var(--fl-font-ui);font-weight:600}
.fl-btn-icon{width:36px;height:36px;padding:0;border-radius:var(--fl-r-sm);background:var(--fl-bg-card);color:var(--fl-text-muted);border:1px solid var(--fl-border)}
.fl-btn-icon:hover{color:var(--fl-text);border-color:var(--fl-border-md);background:var(--fl-bg-hover)}
.fl-card{background:var(--fl-bg-card);border:1px solid var(--fl-border);border-radius:var(--fl-r-lg);padding:20px 24px;transition:border-color var(--fl-t-fast)}
.fl-card:hover{border-color:var(--fl-border-md)}
.fl-card-glow{background:var(--fl-bg-card);border:1px solid var(--fl-border-md);border-radius:var(--fl-r-lg);padding:20px 24px;box-shadow:var(--fl-glow-sm)}
.fl-card-surface{background:var(--fl-bg-surface);border:1px solid var(--fl-border);border-radius:var(--fl-r-md);padding:16px 20px}
.fl-metric{background:var(--fl-bg-card);border:1px solid var(--fl-border);border-radius:var(--fl-r-md);padding:16px 20px;display:flex;flex-direction:column;gap:8px}
.fl-metric-label{font-family:var(--fl-font-mono);font-size:10px;color:var(--fl-text-dim);text-transform:uppercase;letter-spacing:0.08em}
.fl-metric-value{font-family:var(--fl-font-brand);font-size:clamp(14px,2vw,22px);color:var(--fl-text);line-height:1.3}
.fl-metric-sub{font-size:12px;color:var(--fl-text-muted)}
.fl-metric-up{color:var(--fl-success)}.fl-metric-down{color:var(--fl-danger)}
.fl-label{display:block;font-family:var(--fl-font-mono);font-size:10px;color:var(--fl-text-muted);text-transform:uppercase;letter-spacing:0.07em;margin-bottom:8px}
.fl-input,.fl-select,.fl-textarea{width:100%;background:var(--fl-bg-surface);border:1px solid var(--fl-border-md);border-radius:var(--fl-r-sm);color:var(--fl-text);font-family:var(--fl-font-ui);font-size:14px;padding:11px 14px;outline:none;transition:border-color var(--fl-t-fast),box-shadow var(--fl-t-fast);appearance:none}
.fl-input::placeholder,.fl-textarea::placeholder{color:var(--fl-text-dim)}
.fl-input:focus,.fl-select:focus,.fl-textarea:focus{border-color:var(--fl-purple);box-shadow:var(--fl-glow-xs)}
.fl-field{display:flex;flex-direction:column;gap:4px}
.fl-badge{display:inline-flex;align-items:center;gap:5px;font-family:var(--fl-font-mono);font-size:10px;font-weight:500;padding:4px 10px;border-radius:var(--fl-r-full);border:1px solid transparent}
.fl-badge-purple{background:rgba(147,51,234,0.12);color:var(--fl-purple-300);border-color:rgba(147,51,234,0.25)}
.fl-badge-success{background:var(--fl-success-bg);color:var(--fl-success);border-color:rgba(34,197,94,0.2)}
.fl-badge-warning{background:var(--fl-warning-bg);color:var(--fl-warning);border-color:rgba(245,158,11,0.2)}
.fl-badge-danger{background:var(--fl-danger-bg);color:var(--fl-danger);border-color:rgba(239,68,68,0.2)}
.fl-badge-info{background:var(--fl-info-bg);color:var(--fl-info);border-color:rgba(6,182,212,0.2)}
.fl-badge-muted{background:rgba(136,136,160,0.10);color:var(--fl-text-muted);border-color:rgba(136,136,160,0.2)}
.fl-dot{width:6px;height:6px;border-radius:50%;background:currentColor;display:inline-block}
.fl-sidebar{width:220px;background:var(--fl-bg-surface);border-right:1px solid var(--fl-border);height:100vh;display:flex;flex-direction:column;padding:24px 0;position:fixed;left:0;top:0;z-index:100}
.fl-sidebar-logo{padding:0 20px 24px;border-bottom:1px solid var(--fl-border);margin-bottom:12px}
.fl-nav-item{display:flex;align-items:center;gap:10px;padding:10px 20px;font-size:12px;color:var(--fl-text-muted);cursor:pointer;transition:all var(--fl-t-fast);border-left:2px solid transparent;text-decoration:none}
.fl-nav-item:hover{color:var(--fl-text);background:var(--fl-bg-hover)}
.fl-nav-item.active{color:var(--fl-purple-300);background:rgba(147,51,234,0.08);border-left-color:var(--fl-purple)}
.fl-nav-section{font-family:var(--fl-font-mono);font-size:9px;color:var(--fl-text-dim);text-transform:uppercase;letter-spacing:0.1em;padding:16px 20px 6px}
.fl-nav-badge{margin-left:auto;min-width:18px;height:18px;border-radius:var(--fl-r-full);font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 5px}
.fl-kanban-col{background:var(--fl-bg-surface);border:1px solid var(--fl-border);border-radius:var(--fl-r-lg);padding:14px;min-width:220px;flex:1}
.fl-kanban-col-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.fl-kanban-card{background:var(--fl-bg-card);border:1px solid var(--fl-border);border-radius:var(--fl-r-md);padding:14px;margin-bottom:8px;cursor:grab;transition:all var(--fl-t-fast)}
.fl-kanban-card:hover{border-color:var(--fl-border-md);box-shadow:var(--fl-glow-xs);transform:translateY(-2px)}
.fl-kanban-card.dragging{opacity:.5;transform:rotate(2deg)}
.fl-kanban-card-name{font-weight:600;font-size:13px;color:var(--fl-text);margin-bottom:4px}
.fl-kanban-card-meta{font-size:11px;color:var(--fl-text-muted);display:flex;gap:8px;flex-wrap:wrap}
.fl-table{width:100%;border-collapse:collapse}
.fl-table th{font-family:var(--fl-font-mono);font-size:10px;color:var(--fl-text-dim);text-transform:uppercase;letter-spacing:0.08em;text-align:left;padding:10px 14px;border-bottom:1px solid var(--fl-border)}
.fl-table td{padding:12px 14px;font-size:13px;border-bottom:1px solid var(--fl-border);color:var(--fl-text-muted)}
.fl-table tr:last-child td{border-bottom:none}
.fl-table tr:hover td{background:var(--fl-bg-hover);color:var(--fl-text)}
.fl-divider{border:none;border-top:1px solid var(--fl-border);margin:20px 0}
.fl-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.fl-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.fl-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.fl-flex{display:flex;align-items:center;gap:12px}
.fl-between{display:flex;align-items:center;justify-content:space-between}
.fl-col{display:flex;flex-direction:column;gap:8px}
.fl-gap-4{gap:4px}.fl-gap-8{gap:8px}.fl-gap-12{gap:12px}.fl-gap-16{gap:16px}.fl-gap-24{gap:24px}
.fl-text-center{text-align:center}.fl-w-full{width:100%}
.fl-mt-4{margin-top:4px}.fl-mt-8{margin-top:8px}.fl-mt-16{margin-top:16px}.fl-mt-24{margin-top:24px}
.fl-mb-4{margin-bottom:4px}.fl-mb-8{margin-bottom:8px}.fl-mb-16{margin-bottom:16px}.fl-mb-24{margin-bottom:24px}
@media(max-width:768px){
  .fl-sidebar{display:none}
  .fl-grid-4{grid-template-columns:repeat(2,1fr)}
  .fl-grid-3{grid-template-columns:1fr}
  .fl-grid-2{grid-template-columns:1fr}
}
