/* ═══════════════════════════════════════
   ITS DESIGN TOKENS
═══════════════════════════════════════ */
:root {
  --its-sidebar:   #183c5a;
  --its-orange:    #E85928;
  --its-bg:        #f0f2f5;
  --its-white:     #ffffff;
  --its-text:      #1e293b;
  --its-muted:     #64748b;
  --its-border:    #e2e8f0;
  --its-danger:    #dc2626;
  --its-success:   #16a34a;
  --its-warning:   #d97706;
  --its-info:      #0284c7;

  /* Aliases usados pelo resto do código */
  --bg-primary:    var(--its-bg);
  --bg-secondary:  var(--its-white);
  --bg-tertiary:   #f8fafc;
  --bg-card:       var(--its-white);
  --bg-hover:      #f1f5f9;
  --border:        var(--its-border);
  --border-light:  #cbd5e1;
  --text-primary:  var(--its-text);
  --text-secondary:#475569;
  --text-muted:    var(--its-muted);

  --accent:        var(--its-orange);
  --accent-hover:  #d44e22;
  --accent-light:  rgba(232,89,40,0.10);
  --purple:        var(--its-sidebar);
  --pink:          #e85a8a;
  --cyan:          #0284c7;
  --orange:        var(--its-orange);

  --success:       var(--its-success);
  --success-light: rgba(22,163,74,0.12);
  --warning:       var(--its-warning);
  --warning-light: rgba(217,119,6,0.12);
  --danger:        var(--its-danger);
  --danger-light:  rgba(220,38,38,0.10);

  --radius-sm:     6px;
  --radius:        10px;
  --radius-lg:     14px;
  --sidebar-w:     240px;
  --topbar-h:      60px;
  --shadow:        0 4px 16px rgba(0,0,0,0.10);
  --shadow-sm:     0 1px 3px rgba(0,0,0,0.08);
  --shadow-lg:     0 8px 32px rgba(0,0,0,0.13);
  --transition:    0.2s ease;
}

/* ═══════════════════════════════════════
   TEMA ESCURO
═══════════════════════════════════════ */
[data-theme="dark"] {
  --its-bg:        #0f1117;
  --its-white:     #1a1d2e;
  --its-text:      #f1f5f9;
  --its-muted:     #94a3b8;
  --its-border:    #2d3250;

  --bg-primary:    #0f1117;
  --bg-secondary:  #1a1d2e;
  --bg-tertiary:   #21263a;
  --bg-card:       #1a1d2e;
  --bg-hover:      #252a40;
  --border:        #2d3250;
  --border-light:  #3a4060;
  --text-primary:  #f1f5f9;
  --text-secondary:#cbd5e1;
  --text-muted:    #64748b;

  --shadow:        0 4px 24px rgba(0,0,0,0.5);
  --shadow-sm:     0 1px 4px rgba(0,0,0,0.4);
  --shadow-lg:     0 8px 32px rgba(0,0,0,0.6);
}

[data-theme="dark"] .sidebar          { background: #111827; box-shadow: 2px 0 8px rgba(0,0,0,0.4); }
[data-theme="dark"] .topbar           { background: #1a1d2e; border-color: #2d3250; }
[data-theme="dark"] .main-content     { background: #0f1117; }
[data-theme="dark"] .login-card       { background: #1a1d2e; border-color: #2d3250; }
[data-theme="dark"] .login-bg::before { background: radial-gradient(circle,rgba(232,89,40,0.08) 0%,transparent 70%); }
[data-theme="dark"] .input-wrapper    { background: #21263a; border-color: #2d3250; }
[data-theme="dark"] .input-wrapper input { color: #f1f5f9; }
[data-theme="dark"] .input-field,
[data-theme="dark"] .select-field,
[data-theme="dark"] .textarea-field   { background: #21263a; border-color: #2d3250; color: #f1f5f9; }
[data-theme="dark"] .modal            { background: #1a1d2e; border-color: #2d3250; }
[data-theme="dark"] .modal-header,
[data-theme="dark"] .modal-footer     { background: #21263a; border-color: #2d3250; }
[data-theme="dark"] .search-bar       { background: #21263a; border-color: #2d3250; }
[data-theme="dark"] .search-bar input { color: #f1f5f9; }
[data-theme="dark"] th                { background: #111827; }
[data-theme="dark"] tr:hover td       { background: #21263a; }
[data-theme="dark"] .notif-panel,
[data-theme="dark"] .search-results   { background: #1a1d2e; border-color: #2d3250; }
[data-theme="dark"] .toast            { background: #1a1d2e; border-color: #2d3250; }
[data-theme="dark"] .cred-btn         { background: #21263a; border-color: #2d3250; color: #94a3b8; }

/* reset */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Segoe UI',system-ui,sans-serif;
  background:var(--bg-primary);
  color:var(--text-primary);
  min-height:100vh;
  overflow-x:hidden;
  transition:background var(--transition),color var(--transition)
}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,textarea,select{font-family:inherit;border:none;outline:none}
.hidden{display:none!important}

/* SCROLLBAR */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--its-bg)}
::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:#94a3b8}

/* ───────────────────────────────
   LAYOUT
─────────────────────────────── */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;transition:grid-template-columns var(--transition)}
.app.sidebar-collapsed{grid-template-columns:64px 1fr}

/* ───────────────────────────────
   SIDEBAR
─────────────────────────────── */
.sidebar{
  background:var(--its-sidebar);
  border-right:none;
  display:flex;flex-direction:column;
  height:100vh;position:sticky;top:0;
  overflow:hidden;transition:width var(--transition);z-index:100;
  box-shadow:2px 0 8px rgba(0,0,0,0.12)
}
.app.sidebar-collapsed .sidebar{width:64px}
.sidebar-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 16px;
  border-bottom:1px solid rgba(255,255,255,0.08)
}
.sidebar-logo{display:flex;align-items:center;gap:10px;overflow:hidden}
.logo-icon-sm{
  background:var(--its-orange);
  width:30px;height:30px;border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:12px;color:#fff;flex-shrink:0
}
.logo-name{
  font-weight:700;font-size:15px;color:#fff;
  white-space:nowrap
}
.app.sidebar-collapsed .logo-name,
.app.sidebar-collapsed .nav-text,
.app.sidebar-collapsed .user-info,
.app.sidebar-collapsed .nav-label,
.app.sidebar-collapsed .nav-badge{display:none}
.sidebar-toggle{color:rgba(255,255,255,0.5);font-size:18px;padding:4px;border-radius:6px;transition:color var(--transition)}
.sidebar-toggle:hover{color:#fff}
.sidebar-user{
  display:flex;align-items:center;gap:10px;
  padding:14px 16px;
  border-bottom:1px solid rgba(255,255,255,0.08);
  overflow:hidden
}
.user-avatar{
  width:36px;height:36px;border-radius:50%;
  background:var(--its-orange);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:13px;flex-shrink:0;color:#fff
}
.user-info{overflow:hidden}
.user-name{display:block;font-weight:600;font-size:13px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{display:block;font-size:11px;color:rgba(255,255,255,0.45);text-transform:capitalize}
.sidebar-nav{flex:1;overflow-y:auto;padding:10px 0}
.nav-section{margin-bottom:6px}
.nav-label{
  display:block;font-size:10px;font-weight:700;
  color:rgba(255,255,255,0.35);
  text-transform:uppercase;letter-spacing:0.08em;
  padding:8px 16px 4px
}
.nav-item{
  display:flex;align-items:center;gap:8px;
  padding:8px 10px;color:rgba(255,255,255,0.65);
  border-radius:6px;margin:1px 8px;
  transition:all var(--transition);position:relative;
  white-space:nowrap;overflow:hidden;font-size:13px
}
.nav-item:hover{background:rgba(255,255,255,0.08);color:#fff}
.nav-item.active{background:var(--its-orange);color:#fff;font-weight:600}
.nav-item.active::before{display:none}
.nav-icon{font-size:16px;flex-shrink:0;width:20px;text-align:center}
.nav-badge{
  margin-left:auto;background:var(--its-danger);color:#fff;
  font-size:10px;font-weight:700;padding:2px 6px;border-radius:10px;
  min-width:18px;text-align:center
}
.nav-badge.new{background:var(--its-orange)}
.sidebar-footer{
  border-top:1px solid rgba(255,255,255,0.08);
  padding:10px 8px;display:flex;flex-direction:column;gap:2px
}
.btn-theme-toggle,.btn-logout{
  display:flex;align-items:center;gap:10px;
  padding:9px 16px;border-radius:6px;
  color:rgba(255,255,255,0.55);transition:all var(--transition);
  font-size:13px;width:100%
}
.btn-theme-toggle:hover{background:rgba(255,255,255,0.08);color:#fff}
.btn-logout:hover{background:rgba(220,38,38,0.2);color:#fca5a5}

/* ───────────────────────────────
   TOPBAR
─────────────────────────────── */
.topbar{
  height:var(--topbar-h);
  background:var(--its-white);
  border-bottom:1px solid var(--its-border);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;position:sticky;top:0;z-index:90;gap:16px;
  box-shadow:var(--shadow-sm)
}
.topbar-left{display:flex;align-items:center;gap:12px}
.breadcrumb{font-size:15px;font-weight:700;color:var(--its-text)}
.topbar-right{display:flex;align-items:center;gap:10px}
.search-bar{
  display:flex;align-items:center;gap:8px;
  background:var(--its-bg);
  border:1.5px solid var(--its-border);
  border-radius:var(--radius);padding:7px 12px;
  width:240px;transition:border-color var(--transition)
}
.search-bar:focus-within{border-color:var(--its-sidebar)}
.search-icon{font-size:13px;color:var(--its-muted)}
.search-bar input{background:none;color:var(--its-text);font-size:13px;width:100%}
.search-bar input::placeholder{color:var(--its-muted)}
.notif-btn-wrapper{position:relative}
.notif-btn{
  font-size:19px;padding:7px;border-radius:var(--radius-sm);
  position:relative;transition:background var(--transition);color:var(--its-muted)
}
.notif-btn:hover{background:var(--its-bg);color:var(--its-text)}
.notif-dot{
  position:absolute;top:4px;right:4px;
  width:9px;height:9px;background:var(--its-danger);
  border-radius:50%;border:2px solid var(--its-white)
}
.user-menu{
  display:flex;align-items:center;gap:8px;
  padding:5px 10px;border-radius:var(--radius);
  cursor:pointer;transition:background var(--transition);font-size:13px;font-weight:500
}
.user-menu:hover{background:var(--its-bg)}
.user-avatar-sm{
  width:28px;height:28px;border-radius:50%;
  background:var(--its-orange);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:11px;color:#fff
}
.mobile-menu-btn{display:none;font-size:22px;color:var(--its-muted)}

/* ───────────────────────────────
   MAIN CONTENT
─────────────────────────────── */
.main-content{display:flex;flex-direction:column;min-height:100vh;overflow:hidden;background:var(--its-bg)}
.view-container{flex:1;padding:24px;overflow-y:auto}

/* ───────────────────────────────
   LOGIN
─────────────────────────────── */
.login-screen{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;background:var(--its-bg)
}
.login-bg{position:absolute;inset:0;overflow:hidden}
.login-bg::before{
  content:'';position:absolute;
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(24,60,90,0.08) 0%,transparent 70%);
  top:-150px;right:-150px;border-radius:50%
}
.login-bg::after{
  content:'';position:absolute;
  width:400px;height:400px;
  background:radial-gradient(circle,rgba(232,89,40,0.06) 0%,transparent 70%);
  bottom:-100px;left:-100px;border-radius:50%
}
.login-card{
  background:var(--its-white);
  border:1px solid var(--its-border);
  border-radius:var(--radius-lg);
  padding:40px;width:400px;max-width:95vw;
  position:relative;z-index:1;
  box-shadow:var(--shadow-lg)
}
.login-logo{
  display:flex;align-items:center;gap:14px;
  margin-bottom:28px;padding-bottom:20px;
  border-bottom:1px solid var(--its-border)
}
.logo-icon{
  background:var(--its-sidebar);
  border-radius:10px;width:50px;height:50px;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:14px;color:#fff
}
.logo-text h1{font-size:20px;font-weight:800;color:var(--its-sidebar)}
.logo-text p{font-size:12px;color:var(--its-muted);margin-top:2px}
.login-form{display:flex;flex-direction:column;gap:14px}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-group label{font-size:13px;font-weight:600;color:var(--its-text)}
.input-wrapper{
  display:flex;align-items:center;gap:8px;
  background:var(--its-white);
  border:1.5px solid var(--its-border);
  border-radius:var(--radius-sm);padding:10px 12px;
  transition:border-color var(--transition)
}
.input-wrapper:focus-within{border-color:var(--its-sidebar);box-shadow:0 0 0 3px rgba(24,60,90,0.08)}
.input-wrapper input{flex:1;background:none;color:var(--its-text);font-size:14px}
.input-wrapper input::placeholder{color:var(--its-muted)}
.input-icon{font-size:14px;color:var(--its-muted)}
.toggle-password{color:var(--its-muted);font-size:14px}
.error-msg{
  background:#fef2f2;color:var(--its-danger);
  padding:10px 12px;border-radius:var(--radius-sm);
  font-size:13px;border:1px solid #fecaca
}
.login-demo{margin-top:18px;text-align:center}
.login-demo p{font-size:12px;color:var(--its-muted);margin-bottom:8px}
.demo-creds{display:flex;gap:8px;justify-content:center}
.cred-btn{
  background:var(--its-bg);border:1px solid var(--its-border);
  border-radius:var(--radius-sm);padding:5px 10px;
  font-size:11px;color:var(--its-muted);transition:all var(--transition)
}
.cred-btn:hover{background:#fff3ee;border-color:#fdd0be;color:var(--its-orange)}

/* ───────────────────────────────
   BUTTONS
─────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 18px;border-radius:var(--radius-sm);
  font-size:13px;font-weight:600;transition:all var(--transition);cursor:pointer;border:none
}
.btn:hover{filter:brightness(1.06)}
.btn:active{transform:scale(0.98)}
.btn-primary{background:var(--its-orange);color:#fff}
.btn-secondary{background:var(--its-sidebar);color:#fff}
.btn-outline{background:transparent;color:var(--its-sidebar);border:1.5px solid var(--its-sidebar)}
.btn-danger{background:var(--its-danger);color:#fff}
.btn-danger-outline{background:#fef2f2;color:var(--its-danger);border:1px solid #fecaca}
.btn-danger-outline:hover{background:var(--its-danger);color:#fff}
.btn-success{background:#f0fdf4;color:var(--its-success);border:1px solid #bbf7d0}
.btn-success:hover{background:var(--its-success);color:#fff}
.btn-full{width:100%;justify-content:center}
.btn-sm{padding:5px 10px;font-size:12px}
.btn-icon{padding:7px;border-radius:var(--radius-sm)}
.btn-text{background:none;color:var(--its-orange);font-size:13px;padding:4px 8px;border-radius:4px}
.btn-text:hover{background:#fff3ee}
.btn-loader{width:15px;height:15px;border:2px solid rgba(255,255,255,0.3);border-top-color:#fff;border-radius:50%;animation:spin 0.7s linear infinite}

/* ───────────────────────────────
   CARDS
─────────────────────────────── */
.card{
  background:var(--its-white);
  border:1px solid var(--its-border);
  border-radius:var(--radius);padding:20px;
  transition:all 0.2s ease;
  box-shadow:var(--shadow-sm)
}
.card:hover{border-color:#b8d0ea;box-shadow:var(--shadow)}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.card-title{font-size:14px;font-weight:700;color:var(--its-text)}

/* ───────────────────────────────
   STAT CARDS
─────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:20px}
.stat-card{
  background:var(--its-white);
  border:1px solid var(--its-border);
  border-radius:var(--radius);padding:18px;
  position:relative;overflow:hidden;
  transition:all 0.2s ease;
  box-shadow:var(--shadow-sm)
}
.stat-card::before{
  content:'';position:absolute;top:0;right:0;
  width:70px;height:70px;border-radius:50%;opacity:0.08;
  transform:translate(20px,-20px);transition:transform 0.4s ease
}
.stat-card.accent::before{background:var(--its-orange)}
.stat-card.success::before{background:var(--its-success)}
.stat-card.warning::before{background:var(--its-warning)}
.stat-card.danger::before{background:var(--its-danger)}
.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:#b8d0ea}
.stat-card:hover::before{transform:translate(10px,-10px) scale(1.2)}
.stat-icon{font-size:26px;margin-bottom:10px}
.stat-value{font-size:28px;font-weight:800;line-height:1;color:var(--its-sidebar)}
.stat-label{font-size:12px;color:var(--its-muted);margin-top:4px}
.stat-change{font-size:12px;margin-top:6px;display:flex;align-items:center;gap:4px}
.stat-change.up{color:var(--its-success)}
.stat-change.down{color:var(--its-danger)}

/* ───────────────────────────────
   PRIORITY BADGES
─────────────────────────────── */
.priority-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600}
.priority-critica{background:#fef2f2;color:var(--its-danger);border:1px solid #fecaca}
.priority-alta{background:#fff7ed;color:#ea580c;border:1px solid #fed7aa}
.priority-media{background:#fffbeb;color:var(--its-warning);border:1px solid #fde68a}
.priority-baixa{background:#f0fdf4;color:var(--its-success);border:1px solid #bbf7d0}

/* ───────────────────────────────
   LABELS / TAGS
─────────────────────────────── */
.label-tag{display:inline-flex;align-items:center;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;color:#fff}

/* ───────────────────────────────
   TOAST
─────────────────────────────── */
.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{
  background:var(--its-white);
  border:1px solid var(--its-border);
  border-radius:var(--radius-sm);padding:12px 16px;
  min-width:280px;max-width:360px;
  box-shadow:var(--shadow);
  display:flex;align-items:center;gap:10px;
  animation:slideInRight 0.3s ease;font-size:13px
}
.toast.success{border-left:3px solid var(--its-success)}
.toast.error{border-left:3px solid var(--its-danger)}
.toast.warning{border-left:3px solid var(--its-warning)}
.toast.info{border-left:3px solid var(--its-sidebar)}
.toast-icon{font-size:17px;flex-shrink:0}
.toast-close{margin-left:auto;color:var(--its-muted);font-size:15px}

/* ───────────────────────────────
   NOTIFICATION PANEL
─────────────────────────────── */
.notif-panel{
  position:absolute;top:calc(var(--topbar-h) + 8px);right:24px;
  width:340px;background:var(--its-white);
  border:1px solid var(--its-border);
  border-radius:var(--radius);box-shadow:var(--shadow);
  z-index:200;max-height:460px;
  display:flex;flex-direction:column;overflow:hidden
}
.notif-panel-header{padding:14px 16px;border-bottom:1px solid var(--its-border);display:flex;align-items:center;justify-content:space-between}
.notif-panel-header h3{font-size:14px;font-weight:700;color:var(--its-text)}
.notif-list{overflow-y:auto;max-height:380px}
.notif-item{display:flex;gap:10px;padding:12px 14px;border-bottom:1px solid var(--its-border);cursor:pointer;transition:background var(--transition)}
.notif-item:hover{background:var(--its-bg)}
.notif-item.unread{background:#fff3ee}
.notif-item-icon{font-size:19px;flex-shrink:0;margin-top:2px}
.notif-item-content{flex:1;overflow:hidden}
.notif-item-title{font-size:13px;font-weight:600;margin-bottom:2px;color:var(--its-text)}
.notif-item-msg{font-size:12px;color:var(--its-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.notif-item-time{font-size:11px;color:var(--its-muted);margin-top:3px}

/* ───────────────────────────────
   SEARCH RESULTS
─────────────────────────────── */
.search-results{
  position:absolute;top:calc(var(--topbar-h) + 4px);left:50%;transform:translateX(-50%);
  width:480px;background:var(--its-white);
  border:1px solid var(--its-border);border-radius:var(--radius);
  box-shadow:var(--shadow);z-index:200;max-height:380px;overflow-y:auto
}
.search-result-item{display:flex;align-items:center;gap:12px;padding:11px 14px;cursor:pointer;border-bottom:1px solid var(--its-border);transition:background var(--transition)}
.search-result-item:hover{background:var(--its-bg)}
.search-result-title{font-size:13px;font-weight:500;color:var(--its-text)}
.search-result-meta{font-size:11px;color:var(--its-muted)}

/* ───────────────────────────────
   MODAL
─────────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,0.4);
  z-index:1000;display:flex;align-items:center;justify-content:center;
  padding:16px;backdrop-filter:blur(2px);animation:fadeIn 0.15s ease
}
.modal{
  background:var(--its-white);
  border:1px solid var(--its-border);
  border-radius:var(--radius-lg);
  max-height:90vh;overflow:hidden;
  display:flex;flex-direction:column;
  box-shadow:var(--shadow-lg);animation:slideUp 0.2s ease
}
.task-modal-content{width:min(860px,95vw)}
.modal-header{
  display:flex;align-items:flex-start;justify-content:space-between;
  padding:18px 22px;border-bottom:1px solid var(--its-border);
  background:var(--its-white)
}
.modal-title{font-size:16px;font-weight:700;color:var(--its-text)}
.modal-close{font-size:19px;color:var(--its-muted);padding:4px 8px;border-radius:6px}
.modal-close:hover{background:var(--its-bg);color:var(--its-text)}
.modal-body{overflow-y:auto;flex:1}
.modal-footer{
  padding:14px 22px;border-top:1px solid var(--its-border);
  display:flex;gap:10px;justify-content:flex-end;background:var(--its-bg)
}

/* ───────────────────────────────
   FORM ELEMENTS
─────────────────────────────── */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.input-field,.select-field,.textarea-field{
  width:100%;background:var(--its-white);
  border:1.5px solid var(--its-border);
  border-radius:var(--radius-sm);padding:9px 12px;
  color:var(--its-text);font-size:13px;
  transition:border-color var(--transition)
}
.input-field:focus,.select-field:focus,.textarea-field:focus{
  border-color:var(--its-sidebar);outline:none;
  box-shadow:0 0 0 3px rgba(24,60,90,0.08)
}
.select-field{cursor:pointer;-webkit-appearance:none}
.textarea-field{resize:vertical;min-height:80px}
.form-label{
  font-size:12px;font-weight:600;color:var(--its-muted);
  display:block;margin-bottom:5px;
  text-transform:uppercase;letter-spacing:0.04em
}

/* ───────────────────────────────
   PROGRESS BAR
─────────────────────────────── */
.progress-bar{height:6px;background:var(--its-border);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--its-orange),#f97316);border-radius:3px;transition:width 0.4s ease}

/* ───────────────────────────────
   CHIP / TAG
─────────────────────────────── */
.chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:3px 10px;border-radius:20px;font-size:12px;font-weight:500;
  background:var(--its-bg);border:1px solid var(--its-border);color:var(--its-muted)
}

/* ───────────────────────────────
   AVATAR GROUP
─────────────────────────────── */
.avatar-group{display:flex}
.avatar-group .user-avatar{width:26px;height:26px;font-size:10px;margin-left:-7px;border:2px solid var(--its-white)}
.avatar-group .user-avatar:first-child{margin-left:0}

/* ───────────────────────────────
   TABLE
─────────────────────────────── */
.table-wrapper{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--its-border)}
table{width:100%;border-collapse:collapse}
th{
  background:var(--its-sidebar);color:#fff;
  padding:10px 14px;font-size:11px;font-weight:700;
  text-align:left;text-transform:uppercase;letter-spacing:0.05em
}
th:first-child{border-radius:8px 0 0 0}
th:last-child{border-radius:0 8px 0 0}
td{padding:10px 14px;font-size:13px;border-bottom:1px solid var(--its-border)}
tr:last-child td{border-bottom:none}
tr:hover td{background:#f8fafc}

/* ───────────────────────────────
   EMPTY STATE
─────────────────────────────── */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:var(--its-muted)}
.empty-state-icon{font-size:44px;margin-bottom:14px;opacity:0.5}
.empty-state-title{font-size:15px;font-weight:700;color:var(--its-text);margin-bottom:6px}
.empty-state-desc{font-size:13px;max-width:280px}

/* ───────────────────────────────
   LOADER
─────────────────────────────── */
.loader{width:36px;height:36px;border:3px solid var(--its-border);border-top-color:var(--its-orange);border-radius:50%;animation:spin 0.7s linear infinite}
.page-loader{display:flex;align-items:center;justify-content:center;padding:60px}

/* ───────────────────────────────
   ANIMATIONS
─────────────────────────────── */
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideInRight{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.5}}

/* ───────────────────────────────
   RESPONSIVE
─────────────────────────────── */
@media(max-width:768px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-240px;height:100%;z-index:200;transition:left var(--transition)}
  .sidebar.open{left:0}
  .mobile-menu-btn{display:block}
  .search-bar{width:160px}
  .stats-grid{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .search-results{width:95vw;left:50%}
}
@media(max-width:480px){
  .view-container{padding:14px}
  .stats-grid{grid-template-columns:1fr}
  .login-card{padding:24px}
}
