:root{
  --primary:#1a3a5c;--primary-light:#2e6da4;--primary-dark:#0f2235;
  --secondary:#2e86c1;--accent:#17a589;--danger:#e74c3c;--warning:#f39c12;
  --success:#27ae60;--purple:#8e44ad;--info:#2980b9;
  --bg:#f4f6fb;--surface:#fff;--border:#dde2ec;--text:#1e293b;--muted:#6b7280;
  --sidebar-w:248px;--topbar-h:60px;--radius:10px;--shadow:0 2px 12px rgba(0,0,0,.08);
  --shadow-md:0 4px 24px rgba(0,0,0,.12);--transition:.2s ease;
}
*{margin:0;padding:0;box-sizing:border-box;}
html,body{height:100%;font-family:'Inter',sans-serif;font-size:14px;color:var(--text);background:var(--bg);}
a{color:var(--primary-light);text-decoration:none;}
a:hover{color:var(--primary);}

/* ===== AUTH ===== */
.auth-body{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);min-height:100vh;display:flex;align-items:center;justify-content:center;}
.auth-container{display:flex;width:900px;max-width:98vw;min-height:560px;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-md);}
.auth-left{flex:1;background:linear-gradient(160deg,var(--primary-dark) 0%,var(--primary) 100%);padding:48px 40px;display:flex;flex-direction:column;justify-content:center;color:#fff;}
.auth-logo{width:64px;height:64px;background:rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:20px;}
.auth-brand h1{font-size:28px;font-weight:700;margin-bottom:10px;}.auth-brand h1 span{color:#5dade2;}
.auth-brand p{color:rgba(255,255,255,.75);font-size:13px;line-height:1.6;margin-bottom:32px;}
.auth-features{display:flex;flex-direction:column;gap:14px;}
.af-item{display:flex;align-items:center;gap:12px;color:rgba(255,255,255,.88);font-size:13px;}
.af-item i{width:32px;height:32px;background:rgba(255,255,255,.12);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.auth-right{flex:1;background:#fff;padding:48px 44px;display:flex;flex-direction:column;justify-content:center;}
.auth-card{width:100%;}
.auth-card-header{margin-bottom:28px;}.auth-card-header h2{font-size:22px;font-weight:700;color:var(--primary);}.auth-card-header p{color:var(--muted);margin-top:4px;}
.auth-footer-text{margin-top:24px;text-align:center;font-size:11px;color:var(--muted);}
.auth-simple{display:flex;align-items:center;justify-content:center;min-height:100vh;}
.auth-card-sm{width:420px;background:#fff;border-radius:18px;padding:40px;box-shadow:var(--shadow-md);}
.auth-logo-sm{width:52px;height:52px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;margin:0 auto 16px;}
.auth-card-header{text-align:center;margin-bottom:24px;}

/* ===== LAYOUT ===== */
.app-wrapper{display:flex;min-height:100vh;}
.sidebar{width:var(--sidebar-w);background:var(--primary);color:#fff;display:flex;flex-direction:column;flex-shrink:0;transition:width var(--transition);z-index:100;}
.sidebar-brand{display:flex;align-items:center;gap:12px;padding:0 18px;height:var(--topbar-h);border-bottom:1px solid rgba(255,255,255,.12);}
.brand-icon{width:36px;height:36px;background:rgba(255,255,255,.18);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
.brand-text{display:flex;align-items:baseline;gap:4px;}.brand-name{font-size:16px;font-weight:700;}.brand-sub{font-size:12px;color:#5dade2;font-weight:600;}
.sidebar-nav{flex:1;padding:12px 10px;overflow-y:auto;}
.nav-section{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.4);padding:16px 10px 6px;}
.nav-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:8px;color:rgba(255,255,255,.8);font-size:13px;font-weight:500;transition:var(--transition);margin-bottom:2px;}
.nav-item:hover,.nav-item.active{background:rgba(255,255,255,.14);color:#fff;}
.nav-item i{width:18px;text-align:center;font-size:14px;}
.sidebar-footer{padding:14px;border-top:1px solid rgba(255,255,255,.1);}
.sidebar-user{display:flex;align-items:center;gap:10px;}
.sf-avatar,.sf-avatar-init{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0;}
.sf-avatar-init{background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;}
.sf-info{overflow:hidden;}.sf-name{font-size:12px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sf-role{font-size:10px;color:rgba(255,255,255,.5);}
.main-content{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden;}
.topbar{height:var(--topbar-h);background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:16px;position:sticky;top:0;z-index:50;box-shadow:0 1px 0 var(--border);}
.sidebar-toggle{background:none;border:none;cursor:pointer;color:var(--muted);font-size:18px;padding:6px;}
.topbar-title{flex:1;font-size:15px;font-weight:600;color:var(--primary);}
.topbar-right{display:flex;align-items:center;gap:12px;position:relative;}
.user-badge{display:flex;align-items:center;gap:8px;cursor:pointer;padding:6px 10px;border-radius:8px;transition:var(--transition);}
.user-badge:hover{background:var(--bg);}
.user-avatar-sm,.user-avatar-initials{width:34px;height:34px;border-radius:50%;object-fit:cover;flex-shrink:0;}
.user-avatar-initials{background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;}
.user-info-mini{display:flex;flex-direction:column;}.user-name-mini{font-size:13px;font-weight:600;color:var(--text);}
.user-role-mini{font-size:11px;color:var(--muted);}
.user-dropdown{display:none;position:absolute;right:0;top:calc(100%+8px);background:#fff;border:1px solid var(--border);border-radius:10px;min-width:180px;box-shadow:var(--shadow-md);overflow:hidden;z-index:200;}
.user-dropdown.show{display:block;}
.user-dropdown a{display:flex;align-items:center;gap:10px;padding:10px 16px;color:var(--text);font-size:13px;transition:var(--transition);}
.user-dropdown a:hover{background:var(--bg);}
.user-dropdown hr{margin:4px 0;border:none;border-top:1px solid var(--border);}
.user-dropdown .text-danger{color:var(--danger)!important;}
.page-body{flex:1;padding:24px;overflow-y:auto;}

/* ===== PAGE HEADER ===== */
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;}
.page-title{font-size:20px;font-weight:700;color:var(--primary);}
.page-sub{font-size:13px;color:var(--muted);margin-top:3px;}

/* ===== CARDS ===== */
.card{background:#fff;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);margin-bottom:0;}
.card-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border);}
.card-header h3{font-size:14px;font-weight:600;color:var(--primary);display:flex;align-items:center;}
.card-body{padding:20px;}
.card-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;gap:6px;}
.card-body.p-0{padding:0;}
.collapsible{cursor:pointer;user-select:none;}
.form-card{max-width:760px;}

/* ===== STATS ===== */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;}
.stat-card{display:flex;align-items:center;gap:16px;padding:20px;background:#fff;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);}
.stat-icon{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.stat-blue .stat-icon{background:#dbeafe;color:var(--primary-light);}
.stat-green .stat-icon{background:#dcfce7;color:var(--success);}
.stat-purple .stat-icon{background:#f3e8ff;color:var(--purple);}
.stat-orange .stat-icon{background:#fff7ed;color:var(--warning);}
.stat-val{font-size:26px;font-weight:700;color:var(--text);}
.stat-label{font-size:12px;color:var(--muted);margin-top:2px;}

/* ===== DASHBOARD ===== */
.dashboard-grid{display:grid;grid-template-columns:1fr 380px;gap:20px;}
.activity-list{padding:8px 0;max-height:360px;overflow-y:auto;}
.activity-item{display:flex;align-items:flex-start;gap:12px;padding:10px 16px;}
.activity-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;color:#fff;flex-shrink:0;}
.bg-green{background:var(--success);}.bg-blue{background:var(--primary-light);}.bg-red{background:var(--danger);}.bg-purple{background:var(--purple);}.bg-grey{background:var(--muted);}
.activity-text{font-size:12px;font-weight:500;}.activity-meta{font-size:11px;color:var(--muted);margin-top:2px;}

/* ===== TABLES ===== */
.table{width:100%;border-collapse:collapse;}
.table thead th{padding:10px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);background:#fafbfc;border-bottom:1px solid var(--border);}
.table tbody td{padding:12px 16px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle;}
.table tbody tr:last-child td{border-bottom:none;}
.table tbody tr:hover{background:#fafbfd;}
.actions-cell{display:flex;gap:6px;align-items:center;}

/* ===== FORMS ===== */
.form-group{margin-bottom:16px;}
.form-label{display:block;font-size:12px;font-weight:600;color:var(--primary);margin-bottom:6px;}
.form-label.required::after{content:' *';color:var(--danger);}
.form-control{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:inherit;background:#fff;color:var(--text);transition:var(--transition);outline:none;}
.form-control:focus{border-color:var(--primary-light);box-shadow:0 0 0 3px rgba(46,134,193,.12);}
.form-control::placeholder{color:#bbb;}
select.form-control{cursor:pointer;}
textarea.form-control{resize:vertical;line-height:1.5;}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;}
.form-row-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:16px;border-top:1px solid var(--border);}
.form-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--primary);padding-bottom:8px;border-bottom:2px solid var(--primary-light);margin-bottom:16px;}
.input-group{display:flex;gap:8px;align-items:center;}
.input-group .form-control{flex:1;}
.input-icon{position:absolute;left:12px;color:var(--muted);}
.search-bar{margin-bottom:0;}
.input-password{position:relative;}
.input-password .form-control{padding-right:44px;}
.pwd-toggle{position:absolute;right:0;top:0;height:100%;padding:0 12px;background:none;border:none;cursor:pointer;color:var(--muted);}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:var(--transition);text-decoration:none;white-space:nowrap;font-family:inherit;}
.btn:disabled{opacity:.55;cursor:not-allowed;}
.btn-primary{background:var(--primary);color:#fff;}.btn-primary:hover{background:var(--primary-dark);color:#fff;}
.btn-success{background:var(--success);color:#fff;}.btn-success:hover{background:#219a52;}
.btn-blue{background:var(--info);color:#fff;}.btn-blue:hover{background:#2471a3;}
.btn-outline{background:none;border:1px solid var(--border);color:var(--text);}.btn-outline:hover{background:var(--bg);}
.btn-sm{padding:5px 11px;font-size:12px;}
.btn-icon{width:32px;height:32px;padding:0;justify-content:center;border-radius:7px;}
.btn-icon.btn-blue{background:#dbeafe;color:var(--primary-light);}.btn-icon.btn-green{background:#dcfce7;color:var(--success);}
.btn-icon.btn-orange{background:#fff7ed;color:var(--warning);}.btn-icon.btn-red{background:#fee2e2;color:var(--danger);}
.btn-block{width:100%;justify-content:center;}
.btn-group{display:flex;gap:8px;}
.flex-1{flex:1;}
.w-100{width:100%;}

/* ===== BADGES ===== */
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;}
.badge-blue{background:#dbeafe;color:#1d4ed8;}.badge-green,.badge-success{background:#dcfce7;color:#15803d;}
.badge-red,.badge-danger{background:#fee2e2;color:#b91c1c;}.badge-warning{background:#fef3c7;color:#92400e;}
.badge-info{background:#e0f2fe;color:#0369a1;}.badge-purple{background:#f3e8ff;color:#6b21a8;}
.badge-secondary{background:#f1f5f9;color:var(--muted);}.badge-pink{background:#fce7f3;color:#be185d;}
.badge-orange{background:#fff7ed;color:#c2410c;}

/* ===== PATIENT ===== */
.patient-cell{display:flex;align-items:center;gap:10px;}
.patient-avatar{width:34px;height:34px;border-radius:50%;object-fit:cover;flex-shrink:0;}
.patient-avatar-init{display:flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;font-weight:700;font-size:12px;}
.patient-profile-grid{display:grid;grid-template-columns:300px 1fr;gap:20px;}
.patient-profile-card{}.patient-profile-header{text-align:center;padding:24px 20px 16px;}
.patient-profile-avatar,.patient-avatar-init-lg{width:80px;height:80px;border-radius:50%;object-fit:cover;margin:0 auto 12px;}
.patient-avatar-init-lg{display:flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;font-size:26px;font-weight:700;}
.patient-profile-header h2{font-size:17px;font-weight:700;}.patient-code{color:var(--muted);font-size:12px;margin:4px 0 8px;}
.profile-info-list{padding:0 16px 16px;}
.pil-item{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);}
.pil-item:last-child{border:none;}.pil-icon{color:var(--primary-light);width:16px;margin-top:2px;flex-shrink:0;}
.pil-item small{font-size:11px;}
.patient-medical-col{display:flex;flex-direction:column;gap:12px;}
.medical-info-card{border-radius:var(--radius);padding:14px 16px;}.mic-title{font-size:12px;font-weight:700;margin-bottom:6px;display:flex;align-items:center;}
.bg-blue-light{background:#eff6ff;}.bg-red-light{background:#fff1f2;}.bg-orange-light{background:#fff7ed;}

/* ===== CONSULTATIONS — refactor v2 (full width + tabs + horizontal workflow) ===== */
.consultation-layout{display:grid;grid-template-columns:1fr 360px;gap:20px;}
.consult-left{display:flex;flex-direction:column;gap:0;}
.consult-right{}
.consult-full{display:flex;flex-direction:column;gap:0;width:100%;}

/* Workflow stepper horizontal */
.workflow-stepper{display:flex;gap:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px 20px;margin-bottom:18px;box-shadow:var(--shadow-sm);}
.workflow-step{flex:1;display:flex;align-items:center;gap:12px;position:relative;padding:4px 8px;}
.workflow-step:not(:last-child)::after{content:"";position:absolute;top:50%;right:-2px;width:24px;height:2px;background:var(--border);transform:translateY(-50%);}
.workflow-step.completed:not(:last-child)::after{background:var(--success,#16a34a);}
.workflow-step-num{width:34px;height:34px;border-radius:50%;background:var(--border);color:var(--muted);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0;transition:var(--transition);}
.workflow-step.active .workflow-step-num{background:var(--primary);color:#fff;box-shadow:0 0 0 4px rgba(46,134,193,.15);}
.workflow-step.completed .workflow-step-num{background:var(--success,#16a34a);color:#fff;}
.workflow-step.completed .workflow-step-num::before{content:"\f00c";font-family:"Font Awesome 6 Free";font-weight:900;}
.workflow-step.completed .workflow-step-num{font-size:0;}
.workflow-step.completed .workflow-step-num::before{font-size:14px;}
.workflow-step-info{display:flex;flex-direction:column;line-height:1.3;}
.workflow-step-label{font-size:13px;font-weight:600;color:var(--muted);}
.workflow-step.active .workflow-step-label{color:var(--primary);}
.workflow-step.completed .workflow-step-label{color:var(--success,#16a34a);}
.workflow-step-status{font-size:11px;color:var(--muted);font-style:italic;}

/* Symptômes - Onglets */
.symp-tabs-nav{display:flex;gap:6px;border-bottom:2px solid var(--border);margin-bottom:14px;flex-wrap:wrap;padding-bottom:0;}
.symp-tab-btn{padding:8px 14px;background:#f6f8fb;border:1px solid var(--border);border-bottom:none;border-radius:8px 8px 0 0;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;white-space:nowrap;transition:var(--transition);position:relative;display:inline-flex;align-items:center;gap:4px;}
.symp-tab-btn:hover{color:var(--primary);background:#eef4fa;}
.symp-tab-btn.active{color:#fff;background:var(--primary);border-color:var(--primary);}
.symp-tab-btn.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--primary);}
.symp-tab-count{background:#fff;color:var(--primary);border-radius:10px;padding:1px 7px;font-size:10px;font-weight:700;margin-left:4px;border:1px solid currentColor;}
.symp-tab-btn:not(.active) .symp-tab-count{background:var(--primary);color:#fff;border-color:var(--primary);}
.symp-tab-pane{display:none;animation:fadeIn .2s ease;}
.symp-tab-pane.active{display:block;}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px);}to{opacity:1;transform:translateY(0);}}
.symp-tabs-content{min-height:60px;padding:6px 2px;}

/* Symptômes - tags (existants, conservés pour compat) */
.sticky-top{position:sticky;top:calc(var(--topbar-h)+16px);}
.intensity-slider{display:flex;align-items:center;gap:10px;}
.intensity-slider input[type=range]{flex:1;accent-color:var(--primary);}
.intensity-val{font-size:16px;font-weight:700;color:var(--primary);min-width:24px;text-align:center;}
.imc-display{display:flex;align-items:center;gap:8px;margin-top:8px;font-size:13px;}
.symptoms-tags-container{display:flex;flex-wrap:wrap;gap:6px;min-height:28px;margin-bottom:12px;padding:8px 10px;background:var(--bg);border-radius:8px;}
.tag-selected{background:var(--primary);color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500;display:flex;align-items:center;gap:4px;}
.symptoms-categories{display:flex;flex-direction:column;gap:12px;max-height:320px;overflow-y:auto;padding-right:4px;}
.symp-group-title{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;}
.symp-tags{display:flex;flex-wrap:wrap;gap:6px;}
.symp-tag{padding:6px 13px;background:var(--bg);border:1px solid var(--border);border-radius:20px;font-size:12px;cursor:pointer;transition:var(--transition);user-select:none;}
.symp-tag:hover{border-color:var(--primary-light);color:var(--primary);background:#f0f7ff;}
.symp-tag.active{background:var(--primary);color:#fff;border-color:var(--primary);}

/* Barre d'actions consultation */
.consult-actions-bar{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 18px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);margin:8px 0 18px;box-shadow:var(--shadow-sm);position:sticky;bottom:12px;z-index:5;}
.consult-actions-bar .btn{flex:1;}
.btn-outline-primary{background:#fff;color:var(--primary);border:1.5px solid var(--primary);}
.btn-outline-primary:hover{background:var(--primary);color:#fff;}

/* Examen clinique — grille par appareil */
.exam-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;}
.exam-item{display:flex;flex-direction:column;background:#fafbfc;border:1px solid var(--border);border-radius:10px;padding:10px 12px;transition:var(--transition);}
.exam-item:focus-within{border-color:var(--primary-light);background:#fff;box-shadow:0 0 0 3px rgba(46,134,193,.1);}
.exam-item-header{display:flex;align-items:center;gap:8px;margin-bottom:6px;}
.exam-item-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;flex-shrink:0;}
.exam-item-icon.bg-general{background:#64748b;}
.exam-item-icon.bg-cardio{background:#dc2626;}
.exam-item-icon.bg-respi{background:#0ea5e9;}
.exam-item-icon.bg-abdo{background:#f97316;}
.exam-item-icon.bg-neuro{background:#7c3aed;}
.exam-item-icon.bg-orl{background:#16a34a;}
.exam-item-icon.bg-cutane{background:#ec4899;}
.exam-item-icon.bg-locomoteur{background:#0891b2;}
.exam-item-label{font-size:13px;font-weight:600;color:var(--text);}
.exam-item textarea{border:1px solid transparent;background:transparent;padding:6px 4px;font-size:12.5px;resize:vertical;min-height:48px;width:100%;}
.exam-item textarea:focus{outline:none;border-color:transparent;background:transparent;}
.exam-summary-block{margin-top:14px;padding-top:14px;border-top:1px dashed var(--border);}
.preanalyse-card{border:2px solid #10b981;}
.preanalyse-header{background:linear-gradient(135deg,#10b981 0%,#06b6d4 100%);color:#fff;display:flex;justify-content:space-between;align-items:center;}
.preanalyse-header h3{color:#fff;font-size:14px;}
.preanalyse-header small{color:rgba(255,255,255,.85);}
.btn-close-card{background:rgba(255,255,255,.2);border:none;color:#fff;width:28px;height:28px;border-radius:50%;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:var(--transition);}
.btn-close-card:hover{background:rgba(255,255,255,.35);}
.ia-item-danger{border-left:3px solid var(--danger,#dc2626);background:#fef2f2;}
.ia-item-warning{border-left:3px solid #f59e0b;background:#fffbeb;}

/* Statut de réception des résultats par examen et par section */
.presc-progress{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:2px 9px;border-radius:12px;margin-left:8px;letter-spacing:.02em;}
.presc-progress-pending{background:#fef3c7;color:#92400e;}
.presc-progress-partial{background:#dbeafe;color:#1e40af;}
.presc-progress-done{background:#dcfce7;color:#166534;}
.presc-section-complete{background:linear-gradient(to right, rgba(220,252,231,0.3), transparent);border-radius:8px;padding:6px 8px;}
.presc-section-complete .ia-section-title{color:#166534;}

.presc-status{display:inline-flex;align-items:center;font-size:10px;font-weight:600;padding:1px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.04em;}
.presc-status-pending{background:#fef3c7;color:#92400e;}
.presc-status-done{background:#dcfce7;color:#166534;}
.presc-item-done{opacity:.85;background:#fafdf9;border-left:3px solid #16a34a;}
.presc-item-done strong{color:#166534;}

/* Plan thérapeutique - vue ligne par ligne */
.actes-stats{display:flex;gap:12px;flex-wrap:wrap;}
.actes-stat{padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600;border:1px solid var(--border);background:#fff;}
.actes-stat-actif{color:#166534;background:#dcfce7;border-color:#86efac;}
.actes-stat-suspendu{color:#92400e;background:#fef3c7;border-color:#fcd34d;}
.actes-stat-inefficace{color:#991b1b;background:#fee2e2;border-color:#fca5a5;}
.actes-stat-total{color:var(--muted);}
.actes-table{font-size:13px;}
.actes-table th{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);background:#f8fafc;}
.actes-table td{vertical-align:top;padding:10px 8px;}
.acte-line-suspendu{background:linear-gradient(to right,#fffbeb 0%, transparent 100%);}
.acte-line-suspendu strong{color:#92400e;text-decoration:line-through;text-decoration-color:#fbbf24;text-decoration-thickness:1px;}
.acte-line-inefficace{background:linear-gradient(to right,#fef2f2 0%, transparent 100%);opacity:.7;}
.acte-line-inefficace strong{color:#991b1b;text-decoration:line-through;}

/* Décisions cliniques */
.decision-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.decision-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:18px 14px;border-radius:12px;border:2px solid var(--border);background:#fff;cursor:pointer;transition:var(--transition);text-align:center;}
.decision-btn i{font-size:28px;}
.decision-btn span{font-weight:700;font-size:14px;}
.decision-btn small{color:var(--muted);font-size:11px;}
.decision-ambu{color:#16a34a;}
.decision-ambu:hover{background:#f0fdf4;border-color:#16a34a;}
.decision-hospi{color:#2563eb;}
.decision-hospi:hover{background:#eff6ff;border-color:#2563eb;}
.decision-deces{color:#dc2626;}
.decision-deces:hover{background:#fef2f2;border-color:#dc2626;}

/* Modal overlay simple */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.55);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;}
.modal-overlay.d-none{display:none;}
.modal-box{background:#fff;border-radius:14px;width:100%;max-width:500px;max-height:90vh;overflow:auto;box-shadow:var(--shadow-lg,0 10px 30px rgba(0,0,0,.2));}
.modal-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
.modal-header h3{font-size:16px;margin:0;}
.modal-body{padding:18px;}
.modal-footer{padding:12px 18px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;}
.d-flex{display:flex;}
.justify-between{justify-content:space-between;}
.align-center{align-items:center;}
.text-danger{color:var(--danger,#dc2626);}
.text-muted{color:var(--muted);}


/* ===== IA CARD ===== */
.ia-card{border:2px solid var(--primary-light);}
.ia-header{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);}
.ia-header h3{color:#fff;font-size:14px;}.ia-header small{color:rgba(255,255,255,.7);}
.ia-title{display:flex;align-items:center;gap:12px;}
.ia-icon{width:40px;height:40px;background:rgba(255,255,255,.2);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;}
.ia-icon-green{background:rgba(39,174,96,.2)!important;}
.ia-steps{display:flex;flex-direction:column;gap:6px;}
.ia-step{display:flex;align-items:center;gap:10px;padding:6px 10px;border-radius:8px;color:var(--muted);font-size:12px;}
.ia-step.active{background:var(--bg);color:var(--primary);font-weight:600;}
.step-num{width:22px;height:22px;border-radius:50%;background:var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;}
.ia-step.active .step-num{background:var(--primary);color:#fff;}
.ia-loading{text-align:center;padding:24px;}.ia-spinner{font-size:28px;color:var(--primary-light);margin-bottom:8px;}
.ia-loading p{color:var(--muted);font-size:12px;}
.ia-result{margin-top:12px;max-height:400px;overflow-y:auto;}
.ia-result-content{display:flex;flex-direction:column;gap:8px;}
.ia-summary{background:var(--bg);border-left:3px solid var(--primary-light);padding:10px 12px;border-radius:0 8px 8px 0;font-size:12px;color:var(--text);}
.ia-section{}.ia-section-title{font-size:11px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.05em;margin:8px 0 4px;padding-bottom:4px;border-bottom:1px solid var(--border);}
.ia-item{padding:7px 10px;background:#fafbfc;border-radius:7px;margin-bottom:4px;font-size:12px;border:1px solid var(--border);}
.ia-item strong{font-size:13px;}
.ia-actions{}

/* ===== PHOTO UPLOAD ===== */
.photo-upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:28px;text-align:center;cursor:pointer;transition:var(--transition);}
.photo-upload-zone:hover{border-color:var(--primary-light);background:#f0f7ff;}
.photo-upload-zone i{font-size:32px;color:var(--muted);margin-bottom:8px;display:block;}
.photo-upload-zone p{font-size:13px;color:var(--muted);margin-bottom:4px;}
.photo-upload-zone small{font-size:11px;color:var(--border);}
.photos-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;}
.photo-thumb{position:relative;width:80px;height:80px;border-radius:8px;overflow:hidden;border:2px solid var(--border);}
.photo-thumb img{width:100%;height:100%;object-fit:cover;}
.photo-del{position:absolute;top:2px;right:2px;background:var(--danger);color:#fff;border:none;border-radius:50%;width:18px;height:18px;font-size:9px;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.file-preview-list{display:flex;flex-direction:column;gap:4px;}
.file-preview-item{background:var(--bg);padding:6px 10px;border-radius:6px;font-size:12px;color:var(--text);}

/* ===== RESULTS ===== */
.results-list h4{font-size:13px;font-weight:600;margin-bottom:8px;}
.result-file-item{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--border);}
.result-thumb{width:48px;height:48px;border-radius:6px;object-fit:cover;}
.result-icon{width:48px;height:48px;background:#fee2e2;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--danger);font-size:20px;}
.result-info{flex:1;}
.card-prescription-recap{border-left:4px solid var(--info);}

/* ===== VIEW GRID ===== */
.view-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.vitals-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:16px;}
.vital-item{text-align:center;padding:12px;background:var(--bg);border-radius:8px;}
.vital-icon{font-size:18px;color:var(--primary-light);margin-bottom:4px;}
.vital-label{font-size:11px;color:var(--muted);}
.vital-val{font-size:16px;font-weight:700;color:var(--text);}

/* ===== ERROR PAGE ===== */
.error-page{text-align:center;padding:80px 20px;}
.error-code{font-size:96px;font-weight:800;color:var(--primary);opacity:.2;}.error-msg{font-size:22px;font-weight:600;margin-bottom:24px;}

/* ===== ALERT ===== */
.alert{padding:12px 16px;border-radius:8px;font-size:13px;margin-bottom:12px;line-height:1.45;}
.alert > i:first-child{margin-right:8px;}
.alert-danger{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca;}
.alert-warning{background:#fef9c3;color:#854d0e;border:1px solid #fef08a;}

/* ===== TOASTS ===== */
#toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px;}
.toast{display:flex;align-items:center;gap:12px;padding:12px 18px;border-radius:10px;min-width:280px;max-width:380px;box-shadow:var(--shadow-md);font-size:13px;font-weight:500;animation:slideIn .3s ease;pointer-events:auto;}
.toast-success{background:#fff;border-left:4px solid var(--success);color:var(--text);}
.toast-error{background:#fff;border-left:4px solid var(--danger);color:var(--text);}
.toast-warning{background:#fff;border-left:4px solid var(--warning);color:var(--text);}
.toast-info{background:#fff;border-left:4px solid var(--info);color:var(--text);}
.toast-icon{font-size:16px;flex-shrink:0;}
.toast-success .toast-icon{color:var(--success);}.toast-error .toast-icon{color:var(--danger);}
.toast-warning .toast-icon{color:var(--warning);}.toast-info .toast-icon{color:var(--info);}
.toast-close{margin-left:auto;cursor:pointer;color:var(--muted);background:none;border:none;font-size:14px;}
@keyframes slideIn{from{transform:translateX(100%);opacity:0;}to{transform:translateX(0);opacity:1;}}
@keyframes slideOut{from{opacity:1;}to{opacity:0;transform:translateX(30px);}}

/* ===== MODAL ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s;}
.modal-box{background:#fff;border-radius:14px;max-width:440px;width:92%;box-shadow:0 20px 60px rgba(0,0,0,.2);overflow:hidden;animation:scaleIn .25s;}
.modal-header{display:flex;align-items:center;gap:12px;padding:20px 24px;border-bottom:1px solid var(--border);}
.modal-header h3{font-size:15px;font-weight:700;color:var(--text);flex:1;}
.modal-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
.modal-icon-danger{background:#fee2e2;color:var(--danger);}
.modal-body{padding:20px 24px;font-size:14px;color:var(--muted);}
.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--border);background:#fafbfc;}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
@keyframes scaleIn{from{transform:scale(.9);opacity:0;}to{transform:scale(1);opacity:1;}}

/* ===== MISC ===== */
.d-none{display:none!important;}.ms-2{margin-left:8px;}.me-1{margin-right:4px;}.me-2{margin-right:8px;}
.mt-2{margin-top:8px;}.mt-3{margin-top:12px;}.mt-4{margin-top:16px;}.mb-3{margin-bottom:12px;}
.text-center{text-align:center;}.text-right{text-align:right;}.text-muted{color:var(--muted);}
.text-danger{color:var(--danger)!important;}.text-success{color:var(--success);}
.py-4{padding-top:16px;padding-bottom:16px;}.py-5{padding-top:20px;padding-bottom:20px;}
.link-muted{color:var(--muted);font-size:12px;}.link-muted:hover{color:var(--primary);}
.form-check-row{display:flex;justify-content:flex-end;margin-bottom:16px;}
.filter-form{}.mt-3{margin-top:12px;}.mb-3{margin-bottom:12px;}

/* ===== PRINT ===== */
@media print{
  .sidebar,.topbar,.btn,.page-header .btn,.card-header .btn,.actions-cell{display:none!important;}
  .app-wrapper{display:block;}.main-content{display:block;}.page-body{padding:0;}
  .card{border:none;box-shadow:none;}.table tbody tr:hover{background:none;}
}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .dashboard-grid{grid-template-columns:1fr;}
  .consultation-layout{grid-template-columns:1fr;}
  .workflow-stepper{flex-direction:column;gap:12px;}
  .workflow-step:not(:last-child)::after{display:none;}
  .consult-actions-bar{flex-direction:column;}
  .consult-actions-bar .btn{width:100%;}
  .decision-grid{grid-template-columns:1fr;}
  .patient-profile-grid{grid-template-columns:1fr;}
  .view-grid-2{grid-template-columns:1fr;}
}
@media(max-width:768px){
  .sidebar{position:fixed;left:-var(--sidebar-w);height:100%;transition:left var(--transition);}
  .sidebar.open{left:0;}
  .form-row-2,.form-row-3,.form-row-4{grid-template-columns:1fr;}
  .stats-grid{grid-template-columns:1fr 1fr;}
}
/* ═════════════════════════════════════════════════════
   PREMIUM UI — Phase 2 (branding, animations, effects)
   ═════════════════════════════════════════════════════ */

/* Cabinet branding override : --primary et --secondary
   sont injectés depuis header.php via cabinet.couleur_primaire
   et cabinet.couleur_accent. On dérive primary-light. */
:root{
  --primary-light: var(--secondary);
}

/* Transitions globales */
.btn, .nav-item, .stat-card, .card, .trt-tab, .table tr {
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease, color .15s ease;
}

/* Cards : ombre raffinée */
.card {
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--surface);
  box-shadow: 0 1px 3px rgba(0,0,0,.04);
}
.card:hover {
  box-shadow: 0 4px 16px rgba(0,0,0,.06);
}
.card-header {
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: linear-gradient(180deg, rgba(46,134,193,.025) 0%, transparent 100%);
}
.card-header h3 {
  font-size: 15px;
  font-weight: 600;
  color: var(--primary);
}
.card-body { padding: 20px; }
.card-body.p-0 { padding: 0; }

/* Stats : effet hover et gradient subtil */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}
.stat-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 18px;
  display: flex;
  align-items: center;
  gap: 14px;
  position: relative;
  overflow: hidden;
}
.stat-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, transparent 50%, rgba(255,255,255,.4) 100%);
  pointer-events: none;
}
.stat-card:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(0,0,0,.08); }
.stat-icon {
  width: 52px; height: 52px;
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}
.stat-blue   .stat-icon { background: linear-gradient(135deg, #dbeafe, #bfdbfe); color: #1d4ed8; }
.stat-green  .stat-icon { background: linear-gradient(135deg, #d1fae5, #a7f3d0); color: #047857; }
.stat-purple .stat-icon { background: linear-gradient(135deg, #ede9fe, #ddd6fe); color: #6d28d9; }
.stat-orange .stat-icon { background: linear-gradient(135deg, #fed7aa, #fdba74); color: #c2410c; }
.stat-red    .stat-icon { background: linear-gradient(135deg, #fee2e2, #fecaca); color: #b91c1c; }
.stat-val { font-size: 28px; font-weight: 700; color: var(--text); line-height: 1.1; }
.stat-label { font-size: 12px; color: var(--muted); margin-top: 4px; font-weight: 500; }

/* Buttons : micro-interactions */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 16px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn-primary { background: var(--primary); color: #fff; }
.btn-primary:hover { background: var(--primary-dark, #0f2235); color: #fff; box-shadow: 0 4px 12px rgba(26,58,92,.25); }
.btn-success { background: var(--success); color: #fff; }
.btn-success:hover { background: #1f8f4f; color: #fff; }
.btn-warning { background: var(--warning); color: #fff; }
.btn-warning:hover { background: #d6890b; color: #fff; }
.btn-outline { background: transparent; color: var(--primary); border: 1px solid var(--border); }
.btn-outline:hover { background: var(--bg); color: var(--primary); border-color: var(--primary); }
.btn-sm { padding: 6px 11px; font-size: 12px; }
.btn-icon { width: 32px; height: 32px; padding: 0; justify-content: center; }
.btn-green { background: #16a34a; color: #fff; border-color: #16a34a; }
.btn-green:hover { background: #15803d; color: #fff; }
.btn-red { background: #dc2626; color: #fff; border-color: #dc2626; }
.btn-red:hover { background: #b91c1c; color: #fff; }
.btn-orange { background: #d97706; color: #fff; border-color: #d97706; }
.btn-orange:hover { background: #b45309; color: #fff; }

/* Tabs */
.trt-tab {
  position: relative;
}
.trt-tab.active::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0; right: 0;
  height: 3px;
  background: var(--secondary);
  border-radius: 2px 2px 0 0;
}

/* Modal backdrop blur */
.modal-bg {
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
  animation: modalFadeIn .15s ease;
}
.modal-box, .modal-card {
  animation: modalSlideUp .2s ease;
}
@keyframes modalFadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes modalSlideUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Forms */
.form-control {
  width: 100%;
  padding: 9px 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  font-size: 14px;
  font-family: inherit;
  background: #fff;
  color: var(--text);
}
.form-control:focus {
  outline: none;
  border-color: var(--secondary);
  box-shadow: 0 0 0 3px rgba(46,134,193,.12);
}
.form-label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 6px;
}
.form-label.required::after { content:' *'; color: var(--danger); }
.form-group { margin-bottom: 14px; }
.form-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }

/* Tables */
.table {
  width: 100%;
  border-collapse: collapse;
}
.table th {
  text-align: left;
  font-size: 11px;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .04em;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  background: #fafbfd;
}
.table td {
  padding: 12px 14px;
  border-bottom: 1px solid var(--border);
  font-size: 13.5px;
  vertical-align: middle;
}
.table tbody tr:hover { background: rgba(46,134,193,.03); }
.actions-cell { white-space: nowrap; }

/* Badges */
.badge {
  display: inline-block;
  padding: 3px 9px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .02em;
}
.badge-blue      { background: #dbeafe; color: #1d4ed8; }
.badge-green     { background: #d1fae5; color: #047857; }
.badge-orange    { background: #fed7aa; color: #c2410c; }
.badge-red       { background: #fee2e2; color: #b91c1c; }
.badge-pink      { background: #fce7f3; color: #9d174d; }
.badge-purple    { background: #ede9fe; color: #6d28d9; }
.badge-warning   { background: #fef3c7; color: #92400e; }
.badge-success   { background: #d1fae5; color: #047857; }
.badge-info      { background: #dbeafe; color: #1d4ed8; }
.badge-secondary { background: #e5e7eb; color: #374151; }

/* Page header */
.page-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 20px;
  gap: 16px;
  flex-wrap: wrap;
}
.page-title {
  font-size: 22px;
  font-weight: 700;
  color: var(--primary);
  margin-bottom: 4px;
}
.page-sub {
  font-size: 13px;
  color: var(--muted);
}

/* Page body */
.page-body { padding: 22px 26px; }

/* Toasts */
#toast-container {
  position: fixed;
  top: 20px;
  right: 20px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.toast {
  background: #fff;
  border-radius: 10px;
  padding: 14px 18px;
  box-shadow: 0 8px 24px rgba(0,0,0,.12);
  border-left: 4px solid var(--primary);
  max-width: 380px;
  animation: toastIn .25s ease;
}
.toast.success { border-left-color: #16a34a; }
.toast.error   { border-left-color: #dc2626; }
.toast.warning { border-left-color: #d97706; }
@keyframes toastIn { from { opacity:0; transform: translateX(40px); } to { opacity:1; transform: translateX(0); } }

/* User dropdown */
.user-dropdown {
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: 6px;
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 8px 30px rgba(0,0,0,.12);
  padding: 8px;
  min-width: 200px;
  display: none;
  border: 1px solid var(--border);
}
.user-dropdown.show { display: block; }
.user-dropdown a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border-radius: 6px;
  color: var(--text);
  font-size: 13px;
}
.user-dropdown a:hover { background: var(--bg); }
.user-dropdown hr { border: none; border-top: 1px solid var(--border); margin: 6px 0; }

/* Dashboard grid */
.dashboard-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 16px;
}
@media (max-width: 900px) {
  .dashboard-grid { grid-template-columns: 1fr; }
  .form-row-2 { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .stats-grid { grid-template-columns: 1fr; }
  .page-body { padding: 14px; }
}

/* Sidebar mobile */
@media (max-width: 768px) {
  .sidebar {
    position: fixed;
    left: 0; top: 0; bottom: 0;
    transform: translateX(-100%);
    transition: transform .25s ease;
  }
  .sidebar.open { transform: translateX(0); }
  .main-content { margin-left: 0; }
}

/* Spacing helpers */
.me-1 { margin-right: 4px; } .me-2 { margin-right: 8px; }
.ms-1 { margin-left: 4px; }  .ms-2 { margin-left: 8px; }
.mt-1 { margin-top: 4px; }   .mt-2 { margin-top: 8px; }
.text-muted { color: var(--muted); }
.text-danger { color: var(--danger); }
.text-center { text-align: center; }
.py-4 { padding-top: 16px; padding-bottom: 16px; }
.py-5 { padding-top: 20px; padding-bottom: 20px; }
.d-flex { display: flex; }
.gap-2 { gap: 8px; }
.justify-content-end { justify-content: flex-end; }

/* Loading shimmer (utilisable sur les cards en attente AJAX) */
@keyframes shimmer {
  0%   { background-position: -1000px 0; }
  100% { background-position: 1000px 0; }
}
.loading-shimmer {
  background: linear-gradient(90deg, #f3f4f6 0%, #e5e7eb 50%, #f3f4f6 100%);
  background-size: 1000px 100%;
  animation: shimmer 2s infinite;
}

/* Activity feed */
.activity-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 8px;
  max-height: 400px;
  overflow-y: auto;
}
.activity-item {
  display: flex;
  gap: 12px;
  padding: 10px;
  border-radius: 8px;
}
.activity-item:hover { background: var(--bg); }
.activity-icon {
  width: 32px; height: 32px;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  font-size: 13px;
  color: #fff;
}
.activity-icon.bg-blue   { background: #2563eb; }
.activity-icon.bg-green  { background: #16a34a; }
.activity-icon.bg-red    { background: #dc2626; }
.activity-icon.bg-purple { background: #8b5cf6; }
.activity-icon.bg-grey   { background: #64748b; }
.activity-text { font-size: 13px; color: var(--text); line-height: 1.4; }
.activity-meta { font-size: 11px; color: var(--muted); margin-top: 2px; }
