/*
Theme Name: Mireb Workplace
Description: Plateforme SaaS professionnelle tout-en-un
Version: 2.0.0
Author: Mireb Team
Template: astra
Text Domain: mireb-workplace
*/

/* ══════════════════════════════════════════
   VARIABLES & RESET
══════════════════════════════════════════ */
:root {
  --mireb-primary:    #1E3A5F;
  --mireb-secondary:  #F39C12;
  --mireb-accent:     #27AE60;
  --mireb-danger:     #E74C3C;
  --mireb-warning:    #F1C40F;
  --mireb-info:       #3498DB;
  --mireb-light:      #F4F6F9;
  --mireb-dark:       #2C3E50;
  --mireb-white:      #FFFFFF;
  --mireb-gray:       #95A5A6;
  --mireb-gray-light: #F8F9FA;
  --mireb-border:     #E2E8F0;
  --mireb-radius:     12px;
  --mireb-radius-sm:  8px;
  --mireb-radius-xs:  4px;
  --mireb-radius-full:50px;
  --mireb-shadow:         0 4px 15px rgba(0,0,0,0.08);
  --mireb-shadow-sm:      0 2px 8px rgba(0,0,0,0.06);
  --mireb-shadow-md:      0 6px 20px rgba(0,0,0,0.1);
  --mireb-shadow-lg:      0 10px 40px rgba(0,0,0,0.15);
  --mireb-shadow-hover:   0 8px 25px rgba(0,0,0,0.15);
  --mireb-shadow-card:    0 2px 10px rgba(0,0,0,0.06);
  --mireb-shadow-dropdown:0 10px 40px rgba(0,0,0,0.12);
  --mireb-transition:      all 0.3s cubic-bezier(0.4,0,0.2,1);
  --mireb-transition-fast: all 0.15s ease;
  --mireb-sidebar-width:   260px;
  --mireb-header-height:   65px;
  --mireb-font-title: 'Poppins', sans-serif;
  --mireb-font-body:  'Inter', sans-serif;
  /* Devise */
  --mireb-currency: 'FC';
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--mireb-font-body); font-size: 14px; color: var(--mireb-dark); background: var(--mireb-light); line-height: 1.6; -webkit-font-smoothing: antialiased; }
h1,h2,h3,h4,h5,h6 { font-family: var(--mireb-font-title); font-weight: 600; line-height: 1.3; color: var(--mireb-dark); }
a { color: var(--mireb-primary); text-decoration: none; transition: var(--mireb-transition-fast); }
a:hover { color: var(--mireb-secondary); }
img { max-width: 100%; height: auto; }

/* ══════════════════════════════════════════
   BOUTONS
══════════════════════════════════════════ */
.mireb-btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:10px 20px; border:none; border-radius:var(--mireb-radius-sm); font-family:var(--mireb-font-body); font-size:14px; font-weight:500; cursor:pointer; transition:var(--mireb-transition); text-decoration:none; white-space:nowrap; }
.mireb-btn:disabled { opacity:0.6; cursor:not-allowed; transform:none !important; }
.mireb-btn-primary   { background:var(--mireb-primary); color:#fff; }
.mireb-btn-primary:hover   { background:#16304f; color:#fff; transform:translateY(-1px); box-shadow:0 4px 12px rgba(30,58,95,0.3); }
.mireb-btn-secondary { background:var(--mireb-secondary); color:#fff; }
.mireb-btn-secondary:hover { background:#d68910; color:#fff; transform:translateY(-1px); }
.mireb-btn-accent    { background:var(--mireb-accent); color:#fff; }
.mireb-btn-accent:hover    { background:#219a52; color:#fff; transform:translateY(-1px); }
.mireb-btn-danger    { background:var(--mireb-danger); color:#fff; }
.mireb-btn-danger:hover    { background:#c0392b; color:#fff; }
.mireb-btn-outline   { background:transparent; border:2px solid var(--mireb-primary); color:var(--mireb-primary); }
.mireb-btn-outline:hover   { background:var(--mireb-primary); color:#fff; }
.mireb-btn-ghost     { background:transparent; color:var(--mireb-dark); }
.mireb-btn-ghost:hover     { background:var(--mireb-gray-light); }
.mireb-btn-sm  { padding:6px 14px; font-size:12px; }
.mireb-btn-lg  { padding:14px 28px; font-size:16px; border-radius:var(--mireb-radius); }
.mireb-btn-full { width:100%; }
.mireb-btn-icon { width:36px; height:36px; padding:0; border-radius:var(--mireb-radius-sm); }

/* ══════════════════════════════════════════
   BADGES
══════════════════════════════════════════ */
.mireb-badge { display:inline-flex; align-items:center; padding:3px 10px; border-radius:var(--mireb-radius-full); font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:0.5px; }
.mireb-badge-success, .mireb-badge-accent { background:rgba(39,174,96,0.12); color:#1e8449; }
.mireb-badge-warning  { background:rgba(241,196,15,0.15); color:#b7950b; }
.mireb-badge-danger   { background:rgba(231,76,60,0.12);  color:#c0392b; }
.mireb-badge-primary  { background:rgba(30,58,95,0.12);   color:#1E3A5F; }
.mireb-badge-secondary{ background:rgba(243,156,18,0.12); color:#d35400; }
.mireb-badge-gray     { background:rgba(149,165,166,0.15);color:#7F8C8D; }
.mireb-badge-info     { background:rgba(52,152,219,0.12); color:#1a6fa8; }

/* ══════════════════════════════════════════
   FORMULAIRES
══════════════════════════════════════════ */
.mireb-form-group { margin-bottom:18px; }
.mireb-label { display:block; font-size:13px; font-weight:600; color:var(--mireb-dark); margin-bottom:6px; }
.mireb-label .required, .mireb-label span[style*="E74C3C"] { color:var(--mireb-danger); }
.mireb-input,
.mireb-select,
.mireb-textarea { width:100%; padding:10px 14px; border:1.5px solid var(--mireb-border); border-radius:var(--mireb-radius-sm); font-family:var(--mireb-font-body); font-size:14px; color:var(--mireb-dark); background:var(--mireb-white); transition:var(--mireb-transition-fast); outline:none; appearance:none; }
.mireb-input:focus,
.mireb-select:focus,
.mireb-textarea:focus { border-color:var(--mireb-primary); box-shadow:0 0 0 3px rgba(30,58,95,0.1); }
.mireb-input.error  { border-color:var(--mireb-danger); }
.mireb-input.success{ border-color:var(--mireb-accent); }
.mireb-input-icon { position:relative; }
.mireb-input-icon .mireb-input { padding-left:42px; }
.mireb-input-icon .icon { position:absolute; left:14px; top:50%; transform:translateY(-50%); color:var(--mireb-gray); font-size:16px; pointer-events:none; }
.mireb-textarea { resize:vertical; min-height:110px; }
.mireb-form-error { color:var(--mireb-danger); font-size:12px; margin-top:4px; display:flex; align-items:center; gap:4px; }
.mireb-select { background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2395A5A6' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:36px; }

/* ══════════════════════════════════════════
   LAYOUT PRINCIPAL
══════════════════════════════════════════ */
.mireb-layout { display:flex; min-height:100vh; }

/* SIDEBAR */
.mireb-sidebar { width:var(--mireb-sidebar-width); background:var(--mireb-dark); position:fixed; top:0; left:0; height:100vh; z-index:1000; display:flex; flex-direction:column; transition:var(--mireb-transition); overflow-y:auto; scrollbar-width:thin; scrollbar-color:rgba(255,255,255,0.1) transparent; }
.mireb-sidebar.user-sidebar { background:var(--mireb-primary); }
.mireb-sidebar-logo { padding:18px 20px; display:flex; align-items:center; gap:12px; border-bottom:1px solid rgba(255,255,255,0.08); text-decoration:none; flex-shrink:0; }
.mireb-sidebar-logo .logo-text { font-family:var(--mireb-font-title); font-size:14px; font-weight:700; color:#fff; line-height:1.2; }
.mireb-sidebar-logo .logo-subtitle { font-size:10px; color:rgba(255,255,255,0.5); display:block; font-weight:400; }

/* NAV */
.mireb-nav { padding:10px 0; flex:1; }
.mireb-nav-label { padding:10px 20px 4px; font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:1.5px; color:rgba(255,255,255,0.3); }
.mireb-nav-link { display:flex; align-items:center; gap:10px; padding:10px 20px; color:rgba(255,255,255,0.7); font-size:13px; transition:var(--mireb-transition-fast); border-left:3px solid transparent; text-decoration:none; }
.mireb-nav-link:hover { color:#fff; background:rgba(255,255,255,0.06); border-left-color:rgba(255,255,255,0.2); }
.mireb-nav-link.active { color:#fff; background:rgba(255,255,255,0.1); border-left-color:var(--mireb-secondary); font-weight:600; }
.mireb-nav-link .nav-icon { font-size:16px; width:20px; flex-shrink:0; text-align:center; }
.mireb-nav-toggle { margin-left:auto; transition:transform 0.3s; font-size:11px; opacity:0.6; }
.mireb-nav-item.open .mireb-nav-toggle { transform:rotate(180deg); }
.mireb-nav-submenu { display:none; background:rgba(0,0,0,0.1); }
.mireb-nav-submenu.open { display:block; }
.mireb-nav-submenu .mireb-nav-link { padding:8px 20px 8px 50px; font-size:12px; }
.mireb-sidebar-profile { padding:14px 20px; border-top:1px solid rgba(255,255,255,0.08); display:flex; align-items:center; gap:10px; cursor:pointer; transition:var(--mireb-transition-fast); flex-shrink:0; }
.mireb-sidebar-profile:hover { background:rgba(255,255,255,0.04); }
.mireb-sidebar-profile img { width:34px; height:34px; border-radius:50%; object-fit:cover; border:2px solid rgba(255,255,255,0.2); flex-shrink:0; }
.mireb-sidebar-profile .profile-name { font-size:12px; font-weight:600; color:#fff; }
.mireb-sidebar-profile .profile-role { font-size:10px; color:rgba(255,255,255,0.5); margin-top:1px; }
.mireb-sidebar-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:999; }

/* MAIN */
.mireb-main { margin-left:var(--mireb-sidebar-width); flex:1; display:flex; flex-direction:column; min-height:100vh; background:var(--mireb-light); }

/* HEADER */
.mireb-header { height:var(--mireb-header-height); background:var(--mireb-white); box-shadow:0 1px 0 var(--mireb-border),0 2px 8px rgba(0,0,0,0.04); display:flex; align-items:center; padding:0 24px; gap:14px; position:sticky; top:0; z-index:900; }
.mireb-header-left { display:flex; align-items:center; gap:10px; flex:1; min-width:0; }
.mireb-sidebar-toggle { width:36px; height:36px; border:none; background:transparent; border-radius:var(--mireb-radius-sm); cursor:pointer; display:flex; align-items:center; justify-content:center; color:var(--mireb-dark); font-size:18px; transition:var(--mireb-transition-fast); flex-shrink:0; }
.mireb-sidebar-toggle:hover { background:var(--mireb-gray-light); }
.mireb-breadcrumb { display:flex; align-items:center; gap:6px; font-size:12px; color:var(--mireb-gray); white-space:nowrap; }
.mireb-breadcrumb .separator { color:var(--mireb-border); }
.mireb-breadcrumb .current { color:var(--mireb-dark); font-weight:500; }
.mireb-header-search { max-width:320px; width:100%; }
.mireb-search-wrapper { position:relative; }
.mireb-search-input { width:100%; padding:8px 14px 8px 36px; border:1.5px solid var(--mireb-border); border-radius:20px; font-size:13px; background:var(--mireb-gray-light); transition:var(--mireb-transition-fast); outline:none; font-family:var(--mireb-font-body); }
.mireb-search-wrapper .search-icon { position:absolute; left:12px; top:50%; transform:translateY(-50%); color:var(--mireb-gray); font-size:13px; pointer-events:none; }
.mireb-search-input:focus { border-color:var(--mireb-primary); background:var(--mireb-white); box-shadow:0 0 0 3px rgba(30,58,95,0.08); }
.mireb-header-right { display:flex; align-items:center; gap:6px; flex-shrink:0; }
.mireb-header-btn { position:relative; width:38px; height:38px; border:none; background:transparent; border-radius:var(--mireb-radius-sm); cursor:pointer; display:flex; align-items:center; justify-content:center; color:var(--mireb-dark); font-size:18px; transition:var(--mireb-transition-fast); }
.mireb-header-btn:hover { background:var(--mireb-gray-light); }
.mireb-header-btn .badge { position:absolute; top:4px; right:4px; background:var(--mireb-danger); color:#fff; width:16px; height:16px; border-radius:50%; font-size:9px; font-weight:700; display:flex; align-items:center; justify-content:center; }
.mireb-header-avatar { width:34px; height:34px; border-radius:50%; object-fit:cover; border:2px solid var(--mireb-border); cursor:pointer; transition:var(--mireb-transition-fast); }
.mireb-header-avatar:hover { border-color:var(--mireb-primary); }
.mireb-search-results { position:absolute; top:calc(100% + 8px); left:0; right:0; background:#fff; border-radius:var(--mireb-radius-sm); box-shadow:var(--mireb-shadow-dropdown); border:1px solid var(--mireb-border); z-index:100; max-height:280px; overflow-y:auto; }
.search-result-item { padding:10px 16px; display:flex; align-items:center; gap:10px; cursor:pointer; font-size:13px; border-bottom:1px solid var(--mireb-border); transition:var(--mireb-transition-fast); }
.search-result-item:last-child { border-bottom:none; }
.search-result-item:hover { background:var(--mireb-gray-light); }

/* CONTENT */
.mireb-content { padding:24px; flex:1; }

/* PAGE HEADER */
.mireb-page-header { display:flex; align-items:flex-start; justify-content:space-between; margin-bottom:24px; flex-wrap:wrap; gap:12px; }
.mireb-page-title { font-family:var(--mireb-font-title); font-size:22px; font-weight:700; color:var(--mireb-dark); line-height:1.2; }
.mireb-page-subtitle { font-size:13px; color:var(--mireb-gray); margin-top:4px; }

/* ══════════════════════════════════════════
   CARTES
══════════════════════════════════════════ */
.mireb-card { background:var(--mireb-white); border-radius:var(--mireb-radius); box-shadow:var(--mireb-shadow-card); padding:22px; transition:var(--mireb-transition); border:1px solid var(--mireb-border); }
.mireb-card:hover { box-shadow:var(--mireb-shadow-md); }
.mireb-card-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; padding-bottom:14px; border-bottom:1px solid var(--mireb-border); }
.mireb-card-title { font-size:15px; font-weight:600; color:var(--mireb-dark); font-family:var(--mireb-font-title); }

/* ══════════════════════════════════════════
   STATS CARDS
══════════════════════════════════════════ */
.mireb-stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-bottom:24px; }
.mireb-stat-card { background:var(--mireb-white); border-radius:var(--mireb-radius); padding:20px 22px; box-shadow:var(--mireb-shadow-card); border:1px solid var(--mireb-border); transition:var(--mireb-transition); position:relative; overflow:hidden; }
.mireb-stat-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--card-color,var(--mireb-primary)); }
.mireb-stat-card:hover { transform:translateY(-3px); box-shadow:var(--mireb-shadow-md); }
.mireb-stat-card.color-primary   { --card-color:var(--mireb-primary); }
.mireb-stat-card.color-secondary { --card-color:var(--mireb-secondary); }
.mireb-stat-card.color-accent    { --card-color:var(--mireb-accent); }
.mireb-stat-card.color-danger    { --card-color:var(--mireb-danger); }
.mireb-stat-card.color-info      { --card-color:var(--mireb-info); }
.mireb-stat-icon { width:44px; height:44px; border-radius:var(--mireb-radius-sm); display:flex; align-items:center; justify-content:center; font-size:20px; margin-bottom:14px; }
.mireb-stat-card.color-primary   .mireb-stat-icon { background:rgba(30,58,95,0.1);  color:var(--mireb-primary); }
.mireb-stat-card.color-secondary .mireb-stat-icon { background:rgba(243,156,18,0.1);color:var(--mireb-secondary); }
.mireb-stat-card.color-accent    .mireb-stat-icon { background:rgba(39,174,96,0.1); color:var(--mireb-accent); }
.mireb-stat-card.color-danger    .mireb-stat-icon { background:rgba(231,76,60,0.1); color:var(--mireb-danger); }
.mireb-stat-card.color-info      .mireb-stat-icon { background:rgba(52,152,219,0.1);color:var(--mireb-info); }
.mireb-stat-label { font-size:11px; font-weight:600; color:var(--mireb-gray); text-transform:uppercase; letter-spacing:0.6px; margin-bottom:8px; }
.mireb-stat-value { font-family:var(--mireb-font-title); font-size:26px; font-weight:700; color:var(--mireb-dark); line-height:1; margin-bottom:6px; }
.mireb-stat-footer { font-size:11px; color:var(--mireb-gray); margin-top:8px; display:flex; align-items:center; gap:4px; }
.mireb-stat-footer .up   { color:var(--mireb-accent); }
.mireb-stat-footer .down { color:var(--mireb-danger); }

/* ══════════════════════════════════════════
   TABLEAUX
══════════════════════════════════════════ */
.mireb-table-wrapper { overflow-x:auto; border-radius:var(--mireb-radius); }
.mireb-table { width:100%; border-collapse:collapse; min-width:500px; }
.mireb-table thead tr { background:var(--mireb-gray-light); border-bottom:2px solid var(--mireb-border); }
.mireb-table thead th { padding:12px 16px; text-align:left; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.6px; color:var(--mireb-gray); white-space:nowrap; }
.mireb-table tbody tr { border-bottom:1px solid var(--mireb-border); transition:var(--mireb-transition-fast); }
.mireb-table tbody tr:last-child { border-bottom:none; }
.mireb-table tbody tr:hover { background:rgba(30,58,95,0.02); }
.mireb-table tbody td { padding:12px 16px; font-size:13px; vertical-align:middle; }
.mireb-table-actions { display:flex; gap:6px; align-items:center; flex-wrap:nowrap; }

/* ══════════════════════════════════════════
   MODALS
══════════════════════════════════════════ */
.mireb-modal { position:fixed; inset:0; z-index:1100; display:none; align-items:center; justify-content:center; padding:20px; }
.mireb-modal[style*="flex"] { display:flex !important; }
.mireb-modal-overlay { position:absolute; inset:0; background:rgba(0,0,0,0.55); animation:fadeIn 0.2s ease; }
.mireb-modal-box { position:relative; z-index:1; background:var(--mireb-white); border-radius:var(--mireb-radius); box-shadow:0 25px 60px rgba(0,0,0,0.2); width:100%; max-height:90vh; overflow-y:auto; animation:slideUp 0.3s ease; }
.mireb-modal-header { padding:20px 24px; border-bottom:1px solid var(--mireb-border); display:flex; align-items:center; justify-content:space-between; position:sticky; top:0; background:var(--mireb-white); z-index:1; }
.mireb-modal-title { font-size:17px; font-weight:700; font-family:var(--mireb-font-title); color:var(--mireb-dark); }
.mireb-modal-close { width:32px; height:32px; border:none; background:var(--mireb-gray-light); border-radius:50%; cursor:pointer; font-size:18px; display:flex; align-items:center; justify-content:center; transition:var(--mireb-transition-fast); color:var(--mireb-dark); line-height:1; }
.mireb-modal-close:hover { background:var(--mireb-border); }
.mireb-modal-body { padding:24px; }
.mireb-modal-footer { padding:16px 24px; border-top:1px solid var(--mireb-border); display:flex; justify-content:flex-end; gap:10px; background:var(--mireb-gray-light); border-radius:0 0 var(--mireb-radius) var(--mireb-radius); }

/* ══════════════════════════════════════════
   TOAST NOTIFICATIONS
══════════════════════════════════════════ */
.mireb-toast-container { position:fixed; top:80px; right:20px; z-index:9999; display:flex; flex-direction:column; gap:10px; max-width:340px; pointer-events:none; }
.mireb-toast { background:var(--mireb-white); border-radius:var(--mireb-radius-sm); box-shadow:var(--mireb-shadow-dropdown); padding:14px 16px; display:flex; align-items:flex-start; gap:10px; animation:slideInRight 0.3s ease; border-left:4px solid var(--mireb-primary); pointer-events:all; }
.mireb-toast.success { border-left-color:var(--mireb-accent); }
.mireb-toast.error   { border-left-color:var(--mireb-danger); }
.mireb-toast.warning { border-left-color:var(--mireb-secondary); }
.mireb-toast.info    { border-left-color:var(--mireb-info); }
.mireb-toast-icon { font-size:18px; flex-shrink:0; margin-top:1px; }
.mireb-toast-text { flex:1; font-size:13px; line-height:1.5; }
.mireb-toast-close { cursor:pointer; color:var(--mireb-gray); font-size:16px; transition:var(--mireb-transition-fast); margin-left:auto; }
.mireb-toast-close:hover { color:var(--mireb-dark); }

/* ══════════════════════════════════════════
   LOADER
══════════════════════════════════════════ */
.mireb-loader { display:inline-block; width:22px; height:22px; border:3px solid var(--mireb-border); border-top-color:var(--mireb-primary); border-radius:50%; animation:spin 0.7s linear infinite; }
.mireb-loader-sm { width:16px; height:16px; border-width:2px; }

/* ══════════════════════════════════════════
   CRM TOOLBAR
══════════════════════════════════════════ */
.mireb-crm-toolbar { display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin-bottom:18px; padding:14px 18px; background:var(--mireb-white); border-radius:var(--mireb-radius); border:1px solid var(--mireb-border); box-shadow:var(--mireb-shadow-card); }
.mireb-crm-filter-select { padding:8px 12px; border:1.5px solid var(--mireb-border); border-radius:var(--mireb-radius-sm); font-size:13px; color:var(--mireb-dark); background:var(--mireb-white); outline:none; cursor:pointer; font-family:var(--mireb-font-body); }
.mireb-crm-filter-select:focus { border-color:var(--mireb-primary); }

/* ══════════════════════════════════════════
   KANBAN
══════════════════════════════════════════ */
.mireb-kanban { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; overflow-x:auto; }
.mireb-kanban-col { background:var(--mireb-gray-light); border-radius:var(--mireb-radius); padding:14px; min-width:220px; min-height:200px; border:1px solid var(--mireb-border); }
.mireb-kanban-col-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.mireb-kanban-col-title { font-size:13px; font-weight:700; color:var(--mireb-dark); }
.mireb-kanban-col-count { background:var(--mireb-white); color:var(--mireb-gray); font-size:11px; font-weight:700; width:22px; height:22px; border-radius:50%; display:flex; align-items:center; justify-content:center; border:1px solid var(--mireb-border); }
.mireb-kanban-card { background:var(--mireb-white); border-radius:var(--mireb-radius-sm); padding:12px; margin-bottom:10px; box-shadow:var(--mireb-shadow-card); border:1px solid var(--mireb-border); cursor:grab; transition:var(--mireb-transition-fast); }
.mireb-kanban-card:hover { box-shadow:var(--mireb-shadow-md); transform:translateY(-2px); }
.mireb-kanban-card-name { font-size:13px; font-weight:600; color:var(--mireb-dark); margin-bottom:4px; }
.mireb-kanban-card-sub { font-size:11px; color:var(--mireb-gray); }
.mireb-kanban-card-footer { display:flex; align-items:center; justify-content:space-between; margin-top:10px; padding-top:8px; border-top:1px solid var(--mireb-border); }

/* ══════════════════════════════════════════
   DROPDOWN
══════════════════════════════════════════ */
.mireb-dropdown { position:relative; }
.mireb-dropdown-menu { position:absolute; top:calc(100% + 8px); right:0; background:var(--mireb-white); border-radius:var(--mireb-radius-sm); box-shadow:var(--mireb-shadow-dropdown); border:1px solid var(--mireb-border); min-width:180px; z-index:1000; animation:slideDown 0.15s ease; overflow:hidden; display:none; }
.mireb-dropdown-menu.open { display:block; }
.mireb-dropdown-item { display:flex; align-items:center; gap:10px; padding:10px 16px; font-size:13px; color:var(--mireb-dark); transition:var(--mireb-transition-fast); cursor:pointer; border:none; background:none; width:100%; text-align:left; }
.mireb-dropdown-item:hover { background:var(--mireb-gray-light); }
.mireb-dropdown-item.danger { color:var(--mireb-danger); }
.mireb-dropdown-divider { height:1px; background:var(--mireb-border); margin:4px 0; }

/* ══════════════════════════════════════════
   TABS
══════════════════════════════════════════ */
.mireb-tabs { display:flex; gap:2px; border-bottom:2px solid var(--mireb-border); margin-bottom:20px; flex-wrap:wrap; }
.mireb-tab-btn { padding:10px 16px; border:none; background:transparent; color:var(--mireb-gray); font-size:13px; font-weight:500; cursor:pointer; border-bottom:2px solid transparent; margin-bottom:-2px; transition:var(--mireb-transition-fast); border-radius:var(--mireb-radius-sm) var(--mireb-radius-sm) 0 0; font-family:var(--mireb-font-body); }
.mireb-tab-btn:hover { color:var(--mireb-dark); background:var(--mireb-gray-light); }
.mireb-tab-btn.active, .erp-tab-btn.active { color:var(--mireb-primary); border-bottom-color:var(--mireb-primary); font-weight:700; background:transparent; }
.erp-tab-btn { padding:10px 14px; border:none; background:transparent; color:var(--mireb-gray); font-size:13px; cursor:pointer; border-bottom:2px solid transparent; margin-bottom:-2px; transition:var(--mireb-transition-fast); border-radius:var(--mireb-radius-sm) var(--mireb-radius-sm) 0 0; font-family:var(--mireb-font-body); }
.erp-tab-btn:hover { color:var(--mireb-dark); background:var(--mireb-gray-light); }

/* ══════════════════════════════════════════
   ERP — POS (Point de Vente)
══════════════════════════════════════════ */
.mireb-pos { display:grid; grid-template-columns:1fr 360px; gap:0; height:calc(100vh - 160px); min-height:500px; }
.mireb-pos-products { padding:16px; overflow-y:auto; background:var(--mireb-light); }
.mireb-pos-cart { background:var(--mireb-white); border-left:1px solid var(--mireb-border); display:flex; flex-direction:column; overflow:hidden; }
.mireb-pos-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); gap:10px; }
.mireb-pos-product { background:var(--mireb-white); border:2px solid var(--mireb-border); border-radius:var(--mireb-radius-sm); padding:12px 10px; cursor:pointer; transition:var(--mireb-transition); text-align:center; }
.mireb-pos-product:hover { border-color:var(--mireb-primary); transform:translateY(-2px); box-shadow:var(--mireb-shadow-md); }
.mireb-pos-product.out { opacity:0.4; pointer-events:none; }
.mireb-pos-product-icon { font-size:24px; display:block; margin-bottom:6px; }
.mireb-pos-product-name { font-size:11px; font-weight:700; color:var(--mireb-dark); margin-bottom:4px; line-height:1.3; }
.mireb-pos-product-price { font-size:13px; font-weight:700; color:var(--mireb-accent); }
.mireb-pos-product-stock { font-size:10px; color:var(--mireb-gray); margin-top:2px; }
.mireb-pos-cart-header { padding:14px 16px; border-bottom:1px solid var(--mireb-border); font-weight:700; font-size:14px; display:flex; justify-content:space-between; align-items:center; flex-shrink:0; }
.mireb-pos-cart-items { flex:1; overflow-y:auto; padding:8px; }
.mireb-pos-cart-item { display:flex; align-items:center; gap:6px; padding:8px 10px; border-radius:var(--mireb-radius-sm); border:1px solid var(--mireb-border); margin-bottom:6px; background:var(--mireb-white); }
.mireb-pos-cart-item-name { flex:1; font-size:11px; font-weight:600; min-width:0; }
.mireb-pos-qty-ctrl { display:flex; align-items:center; gap:3px; flex-shrink:0; }
.mireb-pos-qty-btn { width:22px; height:22px; border:1px solid var(--mireb-border); background:var(--mireb-gray-light); border-radius:4px; cursor:pointer; font-size:14px; display:flex; align-items:center; justify-content:center; transition:var(--mireb-transition-fast); }
.mireb-pos-qty-btn:hover { background:var(--mireb-primary); color:#fff; border-color:var(--mireb-primary); }
.mireb-pos-qty-val { width:28px; text-align:center; font-size:12px; font-weight:700; }
.mireb-pos-item-total { font-size:11px; font-weight:700; color:var(--mireb-accent); min-width:52px; text-align:right; flex-shrink:0; }
.mireb-pos-item-del { color:var(--mireb-gray); cursor:pointer; font-size:14px; padding:2px 4px; transition:var(--mireb-transition-fast); }
.mireb-pos-item-del:hover { color:var(--mireb-danger); }
.mireb-pos-cart-footer { padding:14px 16px; border-top:1px solid var(--mireb-border); flex-shrink:0; }
.mireb-pos-summary-row { display:flex; justify-content:space-between; font-size:13px; padding:3px 0; }
.mireb-pos-summary-row.total { font-size:18px; font-weight:700; color:var(--mireb-primary); border-top:2px solid var(--mireb-border); padding-top:8px; margin-top:4px; }
.mireb-pos-btn { width:100%; padding:13px; border:none; border-radius:var(--mireb-radius-sm); cursor:pointer; font-size:15px; font-weight:700; font-family:var(--mireb-font-title); transition:var(--mireb-transition); margin-top:8px; }
.mireb-pos-btn.confirm { background:var(--mireb-accent); color:#fff; }
.mireb-pos-btn.confirm:hover { background:#219a52; }
.mireb-pos-btn.confirm:disabled { background:var(--mireb-gray); cursor:not-allowed; }

/* ERP — Présences */
.mireb-att-table th, .mireb-att-table td { padding:7px 4px; text-align:center; font-size:11px; }
.mireb-att-table th.name-col, .mireb-att-table td.name-col { text-align:left; min-width:110px; padding-left:8px; }
.mireb-att-dot { width:24px; height:24px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; font-size:10px; cursor:pointer; border:none; transition:transform 0.15s; }
.mireb-att-dot:hover { transform:scale(1.2); }
.mireb-att-dot.present  { background:rgba(39,174,96,.15); color:#1e8449; }
.mireb-att-dot.absent   { background:rgba(231,76,60,.15);  color:#c0392b; }
.mireb-att-dot.late     { background:rgba(243,156,18,.15); color:#d35400; }
.mireb-att-dot.half     { background:rgba(52,152,219,.15); color:#1a6fa8; }
.mireb-att-dot.none     { background:var(--mireb-gray-light); color:var(--mireb-border); }

/* ERP — Alertes */
.mireb-alert-item { display:flex; align-items:flex-start; gap:10px; padding:12px 14px; border-radius:var(--mireb-radius-sm); margin-bottom:8px; }
.mireb-alert-item.warning { background:rgba(243,156,18,.06); border:1px solid rgba(243,156,18,.2); }
.mireb-alert-item.danger  { background:rgba(231,76,60,.06);  border:1px solid rgba(231,76,60,.2); }
.mireb-alert-item.info    { background:rgba(52,152,219,.06); border:1px solid rgba(52,152,219,.2); }

/* ══════════════════════════════════════════
   ANIMATIONS
══════════════════════════════════════════ */
@keyframes spin { to { transform:rotate(360deg); } }
@keyframes fadeIn { from { opacity:0; } to { opacity:1; } }
@keyframes slideUp { from { opacity:0; transform:translateY(20px); } to { opacity:1; transform:translateY(0); } }
@keyframes slideDown { from { opacity:0; transform:translateY(-10px); } to { opacity:1; transform:translateY(0); } }
@keyframes slideInRight { from { opacity:0; transform:translateX(20px); } to { opacity:1; transform:translateX(0); } }
@keyframes pulse { 0%,100% { transform:scale(1); } 50% { transform:scale(1.05); } }

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media (max-width:1200px) {
  .mireb-stats-grid { grid-template-columns:repeat(2,1fr); }
  .mireb-kanban { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:900px) {
  .mireb-sidebar { transform:translateX(-100%); }
  .mireb-sidebar.open { transform:translateX(0); }
  .mireb-sidebar-overlay { display:block; }
  .mireb-main { margin-left:0; }
  .mireb-header-search { display:none; }
  .mireb-pos { grid-template-columns:1fr; height:auto; }
  .mireb-pos-cart { border-left:none; border-top:1px solid var(--mireb-border); }
}
@media (max-width:600px) {
  .mireb-content { padding:14px; }
  .mireb-stats-grid { grid-template-columns:1fr 1fr; gap:10px; }
  .mireb-stat-value { font-size:20px; }
  .mireb-page-title { font-size:18px; }
  .mireb-kanban { grid-template-columns:1fr; }
  .mireb-crm-toolbar { flex-direction:column; align-items:stretch; }
}
@media (max-width:400px) {
  .mireb-stats-grid { grid-template-columns:1fr; }
}
