:root{--brand-blue:#2563eb;--brand-blue-light:#3b82f6;--brand-blue-glow:#2563eb40;--brand-green:#059669;--brand-green-light:#10b981;--brand-green-glow:#05966933;--bg:#060b18;--bg-2:#0c1426;--bg-3:#111827;--bg-4:#1a2438;--surface:#111827;--surface-2:#1c2a3f;--surface-hover:#1f3048;--border:#ffffff0f;--border-active:#2563eb66;--glass-bg:#111827b3;--glass-border:#ffffff14;--text:#f1f5f9;--text-2:#94a3b8;--text-3:#64748b;--text-4:#475569;--danger:#ef4444;--danger-bg:#ef44441a;--danger-border:#ef444433;--warning:#f59e0b;--warning-bg:#f59e0b1a;--warning-border:#f59e0b33;--success:#10b981;--success-bg:#10b9811a;--success-border:#10b98133;--info:#06b6d4;--info-bg:#06b6d41a;--info-border:#06b6d433;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--r-sm:6px;--r:10px;--r-md:14px;--r-lg:20px;--r-xl:28px;--r-full:9999px;--shadow-sm:0 1px 3px #0006, 0 1px 2px #0000004d;--shadow:0 4px 16px #0006, 0 1px 4px #0000004d;--shadow-lg:0 12px 40px #00000080, 0 4px 16px #0006;--shadow-blue:0 0 0 1px var(--border-active), 0 4px 20px var(--brand-blue-glow);--sidebar-w:240px;--topbar-h:56px;--bottomnav-h:64px;--font:"Sora", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", monospace;--t:.2s ease;--t-slow:.35s cubic-bezier(.4, 0, .2, 1);--t-spring:.4s cubic-bezier(.34, 1.56, .64, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;font-size:14px;line-height:1.6;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(80% 50% at 20% -20%,#2563eb14 0%,#0000 60%),radial-gradient(60% 40% at 80% 110%,#0596690f 0%,#0000 60%);position:fixed;inset:0}ul{list-style:none}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit}img{max-width:100%;display:block}#app{z-index:1;min-height:100dvh;display:flex;position:relative}.sidebar{width:var(--sidebar-w);background:var(--bg-2);border-right:1px solid var(--border);z-index:100;transition:transform var(--t-slow);will-change:transform;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-logo{align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-5);border-bottom:1px solid var(--border);min-height:var(--topbar-h);display:flex}.logo-mark{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.logo-mark.sm{border-radius:6px}.logo-text{letter-spacing:-.3px;background:linear-gradient(135deg, var(--text) 0%, var(--text-2) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:17px;font-weight:700}.sidebar-nav{padding:var(--space-4) var(--space-3);flex-direction:column;flex:1;gap:2px;display:flex;overflow-y:auto}.sidebar-nav .nav-section{letter-spacing:.08em;text-transform:uppercase;color:var(--text-4);padding:var(--space-4) var(--space-3) var(--space-2);font-size:10px;font-weight:600}.sidebar-nav li a,.sidebar-nav li button.nav-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--r);color:var(--text-2);transition:all var(--t);text-align:left;width:100%;font-size:13.5px;font-weight:500;display:flex;position:relative;overflow:hidden}.sidebar-nav li a:before,.sidebar-nav li button.nav-item:before{content:"";background:var(--brand-blue);opacity:0;transition:opacity var(--t);border-radius:var(--r);position:absolute;inset:0}.sidebar-nav li a:hover,.sidebar-nav li button.nav-item:hover{color:var(--text);background:var(--surface-hover)}.sidebar-nav li a.active,.sidebar-nav li button.nav-item.active{color:var(--text);background:var(--surface-2);box-shadow:inset 0 0 0 1px var(--border-active)}.sidebar-nav li a.active .nav-icon,.sidebar-nav li button.nav-item.active .nav-icon{color:var(--brand-blue-light)}.nav-icon{width:18px;height:18px;transition:color var(--t);flex-shrink:0}.nav-badge{background:var(--danger);color:#fff;border-radius:var(--r-full);text-align:center;min-width:18px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:700}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--border)}.user-card{align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--r);cursor:pointer;transition:background var(--t);display:flex}.user-card:hover{background:var(--surface-hover)}.avatar{border-radius:var(--r-full);background:linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-green) 100%);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:700;display:flex}.user-info{flex:1;min-width:0}.user-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.user-role{color:var(--text-3);font-size:11px}.topbar{height:var(--topbar-h);padding:0 var(--space-4);background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:50;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.topbar-logo{align-items:center;gap:var(--space-2);letter-spacing:-.3px;font-size:16px;font-weight:700;display:flex}.topbar-actions{gap:var(--space-2);display:flex}.main-content{min-width:0;min-height:100dvh;padding-bottom:var(--bottomnav-h);flex-direction:column;flex:1;display:flex}.page-container{padding:var(--space-5) var(--space-4);flex:1;width:100%;max-width:1200px;margin:0 auto}.bottom-nav{height:var(--bottomnav-h);background:var(--glass-bg);-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--border);z-index:100;padding-bottom:env(safe-area-inset-bottom);position:fixed;bottom:0;left:0;right:0}.bottom-nav ul{justify-content:space-around;align-items:center;height:100%;display:flex}.bottom-nav li button{padding:var(--space-2) var(--space-3);border-radius:var(--r);color:var(--text-3);transition:all var(--t);flex-direction:column;align-items:center;gap:4px;min-width:56px;font-size:10px;font-weight:600;display:flex}.bottom-nav li button:hover,.bottom-nav li button.active,.bottom-nav li button.active .bnav-icon{color:var(--brand-blue-light)}.bnav-icon{width:22px;height:22px;transition:transform var(--t-spring)}.bottom-nav li button.active .bnav-icon{transform:scale(1.1)}.sidebar-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99;opacity:0;transition:opacity var(--t-slow);background:#0009;position:fixed;inset:0}.sidebar-overlay.visible{opacity:1}.icon-btn{border-radius:var(--r);width:36px;height:36px;color:var(--text-2);transition:all var(--t);justify-content:center;align-items:center;display:flex;position:relative}.icon-btn:hover{background:var(--surface);color:var(--text)}.icon-btn:active{transform:scale(.93)}.notif-dot{background:var(--danger);border:1.5px solid var(--bg);border-radius:50%;width:7px;height:7px;position:absolute;top:7px;right:7px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--space-5);transition:border-color var(--t), box-shadow var(--t)}.card:hover{border-color:var(--glass-border);box-shadow:var(--shadow)}.card-glass{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:var(--space-5)}.card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.card-title{color:var(--text);font-size:14px;font-weight:600}.card-subtitle{color:var(--text-3);margin-top:2px;font-size:12px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--space-5) var(--space-5);transition:all var(--t-slow);position:relative;overflow:hidden}.stat-card:before{content:"";background:linear-gradient(90deg, transparent, var(--accent-glow,var(--brand-blue-glow)), transparent);height:1px;position:absolute;top:0;left:0;right:0}.stat-card:hover{border-color:var(--border-active);box-shadow:var(--shadow-blue);transform:translateY(-2px)}.stat-label{color:var(--text-3);letter-spacing:.02em;font-size:12px;font-weight:500}.stat-value{letter-spacing:-1.5px;margin:var(--space-1) 0;font-size:32px;font-weight:800;line-height:1.1}.stat-change{align-items:center;gap:4px;font-size:12px;font-weight:500;display:flex}.stat-change.up{color:var(--success)}.stat-change.down{color:var(--danger)}.stat-icon{bottom:var(--space-4);right:var(--space-4);opacity:.12;color:var(--text);position:absolute}.btn{justify-content:center;align-items:center;gap:var(--space-2);border-radius:var(--r);font-size:13.5px;font-weight:600;font-family:var(--font);transition:all var(--t);white-space:nowrap;cursor:pointer;border:1px solid #0000;padding:10px 18px;text-decoration:none;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--brand-blue);color:#fff;box-shadow:0 0 0 0 var(--brand-blue-glow)}.btn-primary:hover{background:var(--brand-blue-light);box-shadow:0 4px 20px var(--brand-blue-glow)}.btn-secondary{background:var(--surface-2);color:var(--text);border-color:var(--border)}.btn-secondary:hover{background:var(--surface-hover);border-color:var(--glass-border)}.btn-ghost{color:var(--text-2);border-color:var(--border);background:0 0}.btn-ghost:hover{background:var(--surface);color:var(--text)}.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:var(--danger-border)}.btn-danger:hover{background:#ef44442e}.btn-success{background:var(--success-bg);color:var(--success);border-color:var(--success-border)}.btn-success:hover{background:#10b9812e}.btn-sm{padding:7px 12px;font-size:12px}.btn-lg{padding:13px 24px;font-size:15px}.btn-full{width:100%}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn-icon{flex-shrink:0;width:16px;height:16px}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{color:var(--text-2);letter-spacing:.01em;font-size:12.5px;font-weight:600}.form-control{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r);width:100%;color:var(--text);font-size:14px;font-family:var(--font);transition:all var(--t);-webkit-appearance:none;outline:none;padding:11px 14px}.form-control:focus{border-color:var(--brand-blue);box-shadow:0 0 0 3px var(--brand-blue-glow)}.form-control::placeholder{color:var(--text-4)}.form-control[type=date],.form-control[type=datetime-local]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}textarea.form-control{resize:vertical;min-height:90px}.form-hint{color:var(--text-3);font-size:11.5px}.form-error{color:var(--danger);font-size:11.5px}.input-group{position:relative}.input-group .form-control{padding-left:42px}.input-group .input-icon{width:16px;height:16px;color:var(--text-3);pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.input-suffix .form-control{padding-right:42px}.input-suffix .suffix-btn{color:var(--text-3);cursor:pointer;align-items:center;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.badge{border-radius:var(--r-full);letter-spacing:.02em;align-items:center;gap:4px;padding:3px 9px;font-size:11px;font-weight:600;display:inline-flex}.badge-blue{color:#60a5fa;background:#2563eb26;border:1px solid #2563eb40}.badge-green{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.badge-red{background:var(--danger-bg);color:#f87171;border:1px solid var(--danger-border)}.badge-yellow{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning-border)}.badge-gray{color:var(--text-3);border:1px solid var(--border);background:#ffffff0f}.badge-cyan{background:var(--info-bg);color:var(--info);border:1px solid var(--info-border)}.role-medecin{color:#60a5fa;background:#2563eb26}.role-patient{color:#34d399;background:#10b9811f}.role-admin{color:#fbbf24;background:#f59e0b1f}.role-infirmier{color:#a78bfa;background:#8b5cf61f}.role-pharmacien{color:#22d3ee;background:#06b6d41f}.divider{background:var(--border);height:1px;margin:var(--space-4) 0}.divider-text{align-items:center;gap:var(--space-3);color:var(--text-4);font-size:12px;display:flex}.divider-text:before,.divider-text:after{content:"";background:var(--border);flex:1;height:1px}.table-container{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);overflow:hidden}.table{border-collapse:collapse;width:100%}.table thead th{background:var(--bg-3);padding:var(--space-3) var(--space-4);text-align:left;color:var(--text-3);letter-spacing:.05em;text-transform:uppercase;border-bottom:1px solid var(--border);white-space:nowrap;font-size:11.5px;font-weight:600}.table tbody tr{border-bottom:1px solid var(--border);transition:background var(--t)}.table tbody tr:last-child{border-bottom:none}.table tbody tr:hover{background:var(--surface-hover)}.table tbody td{padding:var(--space-3) var(--space-4);color:var(--text);font-size:13.5px}.modal-backdrop{-webkit-backdrop-filter:blur(8px);z-index:1000;opacity:0;transition:opacity var(--t-slow);background:#000000b3;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}@media (width>=640px){.modal-backdrop{padding:var(--space-5);align-items:center}}.modal-backdrop:not([hidden]){opacity:1}.modal-backdrop:not([hidden]) .modal{transform:translateY(0)scale(1)}.modal{background:var(--bg-3);border:1px solid var(--glass-border);border-radius:var(--r-xl) var(--r-xl) 0 0;width:100%;max-width:520px;max-height:90dvh;transition:transform var(--t-spring);box-shadow:var(--shadow-lg);overflow-y:auto;transform:translateY(60px)scale(.97)}@media (width>=640px){.modal{border-radius:var(--r-xl);max-height:80dvh}}.modal-header{padding:var(--space-5) var(--space-5) var(--space-4);border-bottom:1px solid var(--border);background:var(--bg-3);z-index:1;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.modal-header h3{font-size:16px;font-weight:700}#modal-body{padding:var(--space-5)}.modal-footer{gap:var(--space-3);padding:var(--space-4) var(--space-5);border-top:1px solid var(--border);background:var(--bg-3);justify-content:flex-end;display:flex;position:sticky;bottom:0}#toast-container{top:var(--space-4);right:var(--space-4);z-index:2000;gap:var(--space-2);max-width:360px;width:calc(100% - var(--space-8));flex-direction:column;display:flex;position:fixed}.toast{align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-4);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-lg);opacity:0;pointer-events:auto;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;transform:translate(calc(100% + 20px))}.toast.show{opacity:1;transform:translate(0)}.toast.hide{opacity:0;transition:all .25s ease-in;transform:translate(calc(100% + 20px))}.toast-icon{flex-shrink:0;width:16px;height:16px;margin-top:1px}.toast-success{border-left:3px solid var(--success)}.toast-error{border-left:3px solid var(--danger)}.toast-warning{border-left:3px solid var(--warning)}.toast-info{border-left:3px solid var(--info)}.toast-title{font-size:13px;font-weight:600}.toast-msg{color:var(--text-2);margin-top:2px;font-size:12px}.skeleton{background:linear-gradient(90deg, var(--bg-3) 0%, var(--surface-2) 50%, var(--bg-3) 100%);border-radius:var(--r);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.page-enter{animation:.3s cubic-bezier(.4,0,.2,1) forwards pageEnter}@keyframes pageEnter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.stagger>*{opacity:0;animation:.3s forwards fadeUp}.stagger>:first-child{animation-delay:0s}.stagger>:nth-child(2){animation-delay:50ms}.stagger>:nth-child(3){animation-delay:.1s}.stagger>:nth-child(4){animation-delay:.15s}.stagger>:nth-child(5){animation-delay:.2s}.stagger>:nth-child(6){animation-delay:.25s}.stagger>:nth-child(7){animation-delay:.3s}.stagger>:nth-child(8){animation-delay:.35s}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.grid-2{gap:var(--space-4);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.grid-4{gap:var(--space-4);grid-template-columns:repeat(4,1fr);display:grid}.grid-auto{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.bento{gap:var(--space-4);grid-template-columns:repeat(4,1fr);display:grid}.bento .span-2{grid-column:span 2}.bento .span-3{grid-column:span 3}.bento .span-4{grid-column:span 4}.page-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap;display:flex}.page-title{letter-spacing:-.5px;font-size:22px;font-weight:800}.page-subtitle{color:var(--text-3);margin-top:2px;font-size:13px}.tabs{background:var(--bg-3);border-radius:var(--r);border:1px solid var(--border);scrollbar-width:none;gap:2px;padding:3px;display:flex;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab-btn{border-radius:calc(var(--r) - 2px);color:var(--text-3);transition:all var(--t);white-space:nowrap;flex-shrink:0;padding:7px 14px;font-size:13px;font-weight:500}.tab-btn:hover{color:var(--text)}.tab-btn.active{background:var(--surface-2);color:var(--text);box-shadow:var(--shadow-sm)}.accordion-item{border:1px solid var(--border);border-radius:var(--r-md);margin-bottom:var(--space-2);transition:border-color var(--t);overflow:hidden}.accordion-item:hover{border-color:var(--glass-border)}.accordion-item.open{border-color:var(--border-active)}.accordion-trigger{width:100%;padding:var(--space-4) var(--space-5);background:var(--surface);text-align:left;color:var(--text);transition:background var(--t);justify-content:space-between;align-items:center;font-size:14px;font-weight:600;display:flex}.accordion-trigger:hover{background:var(--surface-hover)}.accordion-chevron{width:16px;height:16px;color:var(--text-3);transition:transform var(--t-slow)}.accordion-item.open .accordion-chevron{transform:rotate(180deg)}.accordion-body{padding:var(--space-5);background:var(--bg-3);border-top:1px solid var(--border);display:none}.accordion-item.open .accordion-body{display:block}.timeline{position:relative}.timeline:before{content:"";background:var(--border);width:1px;position:absolute;top:4px;bottom:0;left:18px}.timeline-item{gap:var(--space-4);padding-bottom:var(--space-5);display:flex;position:relative}.timeline-dot{border-radius:var(--r-full);background:var(--surface-2);border:2px solid var(--border);z-index:1;width:36px;height:36px;transition:all var(--t);flex-shrink:0;justify-content:center;align-items:center;display:flex}.timeline-dot.active{background:var(--brand-blue-glow);border-color:var(--brand-blue)}.timeline-content{flex:1}.timeline-date{color:var(--text-3);margin-bottom:4px;font-size:11.5px}.timeline-title{margin-bottom:var(--space-2);font-size:14px;font-weight:600}.vital-row{padding:var(--space-3) 0;border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.vital-row:last-child{border-bottom:none}.vital-label{color:var(--text-2);font-size:13px}.vital-value{font-size:14px;font-weight:700;font-family:var(--font-mono)}.vital-value.normal{color:var(--success)}.vital-value.warning{color:var(--warning)}.vital-value.danger{color:var(--danger)}.chip-group{gap:var(--space-2);padding:var(--space-3);background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r);flex-wrap:wrap;min-height:50px;display:flex}.chip{align-items:center;gap:var(--space-2);background:var(--surface-2);border:1px solid var(--border-active);border-radius:var(--r-full);color:var(--brand-blue-light);animation:chipIn .2s var(--t-spring);padding:5px 10px;font-size:12.5px;font-weight:500;display:inline-flex}@keyframes chipIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.chip-remove{cursor:pointer;opacity:.6;width:14px;height:14px;transition:opacity var(--t)}.chip-remove:hover{opacity:1}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.status-dot.active{background:var(--success);box-shadow:0 0 6px var(--success)}.status-dot.warning{background:var(--warning);box-shadow:0 0 6px var(--warning)}.status-dot.danger{background:var(--danger);box-shadow:0 0 6px var(--danger)}.status-dot.inactive{background:var(--text-4)}@keyframes pulse-ring{0%{opacity:1;transform:scale(1)}70%{opacity:0;transform:scale(1.5)}to{opacity:0;transform:scale(1.5)}}.pulse-danger{justify-content:center;align-items:center;display:inline-flex;position:relative}.pulse-danger:before{content:"";background:var(--danger);border-radius:50%;animation:1.5s ease-out infinite pulse-ring;position:absolute;inset:-4px}.empty-state{padding:var(--space-12) var(--space-6);text-align:center;justify-content:center;align-items:center;gap:var(--space-4);flex-direction:column;display:flex}.empty-icon{border-radius:var(--r-xl);background:var(--surface-2);width:64px;height:64px;color:var(--text-4);justify-content:center;align-items:center;display:flex}.empty-title{font-size:16px;font-weight:700}.empty-subtitle{color:var(--text-3);max-width:280px;font-size:13px}.spinner{border:2px solid var(--border);border-top-color:var(--brand-blue);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.alert{gap:var(--space-3);padding:var(--space-4);border-radius:var(--r);font-size:13.5px;line-height:1.5;display:flex}.alert-icon{flex-shrink:0;width:18px;height:18px;margin-top:1px}.alert-danger{background:var(--danger-bg);border:1px solid var(--danger-border);color:#fca5a5}.alert-warning{background:var(--warning-bg);border:1px solid var(--warning-border);color:#fcd34d}.alert-success{background:var(--success-bg);border:1px solid var(--success-border);color:#6ee7b7}.alert-info{background:var(--info-bg);border:1px solid var(--info-border);color:var(--info)}.qr-container{align-items:center;gap:var(--space-4);padding:var(--space-6);border-radius:var(--r-lg);background:#fff;flex-direction:column;max-width:280px;margin:0 auto;display:flex}.qr-container img{width:200px;height:200px;image-rendering:pixelated}*{scrollbar-width:thin;scrollbar-color:var(--surface-2) transparent}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--surface-2);border-radius:2px}.search-bar{align-items:center;gap:var(--space-3);padding:0 var(--space-4);background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r);transition:all var(--t);display:flex}.search-bar:focus-within{border-color:var(--brand-blue);box-shadow:0 0 0 3px var(--brand-blue-glow)}.search-bar input{color:var(--text);font-size:14px;font-family:var(--font);background:0 0;border:none;outline:none;flex:1;padding:10px 0}.search-bar input::placeholder{color:var(--text-4)}.filters-row{gap:var(--space-2);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.cal-header{text-align:center;color:var(--text-3);padding:var(--space-2);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:600}.cal-day{aspect-ratio:1;border-radius:var(--r);cursor:pointer;transition:all var(--t);color:var(--text-2);justify-content:center;align-items:center;font-size:13px;display:flex;position:relative}.cal-day:hover{background:var(--surface-hover);color:var(--text)}.cal-day.today{background:var(--brand-blue-glow);color:var(--brand-blue-light);font-weight:700}.cal-day.has-event:after{content:"";background:var(--brand-green-light);border-radius:50%;width:4px;height:4px;position:absolute;bottom:4px}.cal-day.selected{background:var(--brand-blue);color:#fff;font-weight:700}.cal-day.other-month{color:var(--text-4)}.stock-bar{background:var(--bg-4);height:4px;margin-top:var(--space-2);border-radius:2px;overflow:hidden}.stock-fill{border-radius:2px;height:100%;transition:width .6s}.stock-ok .stock-fill{background:var(--success)}.stock-warning .stock-fill{background:var(--warning)}.stock-danger .stock-fill{background:var(--danger)}@media (width>=640px){.page-container{padding:var(--space-6) var(--space-6)}.topbar,.bottom-nav{display:none}.sidebar{transform:translate(0)}.main-content{margin-left:var(--sidebar-w);padding-bottom:0}.bento{grid-template-columns:repeat(4,1fr)}}@media (width<=639px){.sidebar{width:280px}.grid-2,.grid-3{grid-template-columns:1fr}.grid-4,.bento{grid-template-columns:repeat(2,1fr)}.bento .span-2,.bento .span-3,.bento .span-4{grid-column:span 2}.page-title{font-size:18px}}@media (width>=1024px){.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.page-container{padding:var(--space-8) var(--space-8)}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.wrap{flex-wrap:wrap}.flex-1{flex:1}.min-w-0{min-width:0}.w-full{width:100%}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.text-sm{font-size:12px}.text-muted{color:var(--text-3)}.text-danger{color:var(--danger)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.font-bold{font-weight:700}.font-mono{font-family:var(--font-mono)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.hidden{display:none!important}.sr-only{clip:rect(0,0,0,0);width:1px;height:1px;position:absolute;overflow:hidden}.topbar-avatar{background:linear-gradient(135deg, var(--brand-blue), var(--brand-green));color:#fff;border:1px solid var(--border-active);width:32px;height:32px;transition:transform var(--t);border-radius:50%;justify-content:center;align-items:center;font-size:12.5px;font-weight:700;text-decoration:none;display:flex}.topbar-avatar:hover{transform:scale(1.05)}.notif-dropdown{background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--r-lg);z-index:500;width:340px;animation:.2s fadeIn;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 10px 30px #00000080}.notif-dropdown.hidden{display:none}.notif-dropdown-header{padding:12px var(--space-4);border-bottom:1px solid var(--border);background:var(--bg-2);justify-content:space-between;align-items:center;display:flex}.notif-list{max-height:360px;overflow-y:auto}.notif-item{gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--t);align-items:flex-start;display:flex;position:relative}.notif-item:hover{background:var(--surface-hover)}.notif-item.unread{background:#2563eb08}.notif-unread-dot{background:var(--brand-blue-light);border-radius:50%;width:6px;height:6px;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.notif-icon{border-radius:var(--r-sm);flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.notif-content{flex:1;min-width:0}.notif-title{color:var(--text);font-size:13px;font-weight:700}.notif-body{color:var(--text-2);margin-top:2px;font-size:12px;line-height:1.4}.notif-time{color:var(--text-3);margin-top:4px;font-size:10.5px}.notif-dropdown-footer{padding:8px var(--space-4);background:var(--bg-2);border-top:1px solid var(--border);text-align:center}.notif-empty{padding:var(--space-6);text-align:center;color:var(--text-3);font-size:13px}.nav-item-danger{color:#fca5a5!important}.nav-item-danger:hover{color:#ef4444!important;background:#dc26261a!important}.urgence-demo-btns{gap:6px;margin-top:10px;display:flex}.btn-chip{background:var(--bg-3);border:1px solid var(--border);color:var(--text-2);cursor:pointer;transition:all var(--t);white-space:nowrap;border-radius:16px;padding:5px 12px;font-size:11.5px;font-weight:600}.btn-chip:hover{border-color:var(--glass-border);color:var(--text)}.btn-chip.active{background:var(--brand-blue-glow);border-color:var(--brand-blue);color:var(--brand-blue-light)}
