:root{--primary:#1A4A9C;--primary-hover:#0E3278;--primary-light:#C8D9F5;--secondary:#6B7589;--sec-light:#EAECEF;--border:#A0A8B4;--border-dark:#6B7589;--border-light:#D6D9E0;--accent:#B40000;--accent-hover:#8C0000;--success:#1A7A1A;--success-light:#D4EFD4;--warning:#D06000;--warning-light:#FDEFD0;--info:#0C6FBF;--info-light:#D0E8F8;--text:#1A1A1A;--text-sec:#4A4A5A;--app-bg:#D4D8E0;--card-bg:#FFFFFF;--topbar-bg-solid:#1A3A90;--topbar-border:#0A1A50;--navbar-bg:linear-gradient(180deg,#E8ECF4 0%,#CDD4E4 100%);--navbar-border:#8A96B0;--sidebar-bg-solid:#1C3060;--sidebar-hover:#3A5A9A;--sidebar-active:#4A6AAA;--statusbar-bg:linear-gradient(180deg,#E4E8EE 0%,#C8CDD8 100%);--shadow-sm:1px 1px 2px rgba(0,0,0,.25),inset 0 1px 0 rgba(255,255,255,.5);--shadow-md:2px 2px 5px rgba(0,0,0,.30);--shadow-lg:3px 3px 8px rgba(0,0,0,.35);--radius:0px;--radius-sm:0px;--font:Tahoma,'Segoe UI',Arial,sans-serif;--font-mono:'Courier New',Consolas,monospace;--sidebar-w:195px;--topbar-h:48px;--navbar-h:30px;--statusbar-h:22px}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px;height:100%}
body{font-family:var(--font);font-size:12px;color:var(--text);background:#D4D8E0;height:100%;overflow:hidden}
a{color:var(--primary);text-decoration:underline}
a:hover{color:var(--primary-hover)}
input,select,textarea,button{font-family:var(--font);font-size:12px}
ul{list-style:none}
img{max-width:100%}
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:#D0D0D0;border-left:1px solid #A0A0A0}
::-webkit-scrollbar-thumb{background:linear-gradient(90deg,#F0F0F0 0%,#C8C8C8 50%,#A8A8A8 100%);border:1px solid #808080}
::-webkit-scrollbar-thumb:hover{background:linear-gradient(90deg,#D8E8F8 0%,#A0C0E0 50%,#80A8C8 100%)}

#app{display:flex;flex-direction:column;height:100vh;height:100dvh}

#topbar{height:var(--topbar-h);background:linear-gradient(180deg,#2A5AD0 0%,#1A3A90 40%,#122A70 100%);border-bottom:2px solid #0A1A50;box-shadow:0 2px 4px rgba(0,0,0,.40);display:flex;align-items:center;justify-content:space-between;padding:0 10px;flex-shrink:0;z-index:300;position:relative}
#topbar::after{content:'';position:absolute;top:0;left:0;right:0;height:24px;background:linear-gradient(180deg,rgba(255,255,255,.22) 0%,transparent 100%);pointer-events:none}
.tb-left{display:flex;align-items:center;gap:8px;position:relative;flex:1;min-width:0}
.tb-menu-btn{background:none;border:none;color:rgba(255,255,255,.8);font-size:16px;cursor:pointer;padding:4px 6px;display:none;line-height:1;flex-shrink:0}
.tb-menu-btn:hover{color:#fff}
.tb-logo-link{display:flex;align-items:center;flex-shrink:0;text-decoration:none}
.tb-logo-img{height:26px;width:auto;flex-shrink:0}
.tb-app-name{font-size:14px;font-weight:700;color:#FFFFFF;letter-spacing:.03em;cursor:pointer;text-shadow:0 1px 3px rgba(0,0,0,.6);white-space:nowrap;flex-shrink:0}
.tb-app-badge{font-size:9px;background:linear-gradient(180deg,#4A8AE8 0%,#1A4AAC 100%);color:#fff;padding:1px 5px;border:1px solid #0A2A7C;font-weight:700;flex-shrink:0}
.tb-sep{width:1px;height:22px;background:rgba(255,255,255,.2);border-right:1px solid rgba(0,0,0,.3);flex-shrink:0}
.tb-search{position:relative;display:flex;align-items:center;flex:1;max-width:260px}
.tb-search input{width:100%;height:24px;background:#F0F4FF;border:1px solid #6882C0;border-top-color:#3A5AA0;border-left-color:#3A5AA0;color:#1A1A1A;padding:0 26px 0 6px;font-size:11px;outline:none;box-shadow:inset 1px 1px 3px rgba(0,0,0,.20)}
.tb-search input::placeholder{color:#8090B0}
.tb-search input:focus{border-color:#2A5AC0;background:#FFFFFF}
.tb-search>svg{position:absolute;right:6px;color:#5070A0;pointer-events:none}
#tb-qs-results{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #8A96B0;border-top:none;z-index:500;max-height:260px;overflow-y:auto;display:none;box-shadow:2px 2px 6px rgba(0,0,0,.2)}
.tb-right{display:flex;align-items:center;gap:6px;flex-shrink:0}
.tb-clock{font-size:11px;color:#B8D0FF;font-family:var(--font-mono);white-space:nowrap;text-shadow:0 1px 2px rgba(0,0,0,.4)}
.tb-notif-btn{position:relative;background:linear-gradient(180deg,rgba(255,255,255,.18) 0%,rgba(255,255,255,.05) 100%);border:1px solid rgba(255,255,255,.25);border-bottom-color:rgba(0,0,0,.2);cursor:pointer;color:#CCDCFF;padding:3px 7px;display:flex;align-items:center;box-shadow:inset 0 1px 0 rgba(255,255,255,.15),0 1px 2px rgba(0,0,0,.2)}
.tb-notif-btn:hover{background:linear-gradient(180deg,rgba(255,255,255,.28) 0%,rgba(255,255,255,.10) 100%);color:#fff}
.notif-badge{position:absolute;top:-2px;right:-2px;background:linear-gradient(180deg,#FF4040 0%,#CC0000 100%);color:#fff;font-size:8px;font-weight:700;min-width:13px;height:13px;display:flex;align-items:center;justify-content:center;padding:0 3px;border:1px solid #800000}
.tb-user-btn{display:flex;align-items:center;gap:5px;background:linear-gradient(180deg,rgba(255,255,255,.18) 0%,rgba(255,255,255,.05) 100%);border:1px solid rgba(255,255,255,.25);border-bottom-color:rgba(0,0,0,.2);color:#E0ECFF;padding:3px 10px;cursor:pointer;font-size:11px;font-weight:700}
.tb-user-btn:hover{background:linear-gradient(180deg,rgba(255,255,255,.28) 0%,rgba(255,255,255,.10) 100%);color:#fff}
.tb-logout-btn{display:flex;align-items:center;padding:4px 6px;color:rgba(255,255,255,.6);text-decoration:none;border:1px solid rgba(255,255,255,.2);background:rgba(0,0,0,.15)}
.tb-logout-btn:hover{color:#fff;background:rgba(180,0,0,.5)}

#navbar{height:var(--navbar-h);background:linear-gradient(180deg,#E8ECF4 0%,#CDD4E4 100%);border-bottom:1px solid #8A96B0;box-shadow:0 1px 3px rgba(0,0,0,.20),inset 0 -1px 0 #B0BAD0;display:flex;align-items:flex-end;padding:0 4px;flex-shrink:0;z-index:290;overflow-x:auto;overflow-y:hidden;scrollbar-width:none}
#navbar::-webkit-scrollbar{display:none}
.nav-tab{display:inline-flex;align-items:center;gap:4px;padding:4px 12px 3px;font-size:11px;font-weight:700;color:#2A3A5A;background:linear-gradient(180deg,#E0E6F0 0%,#C8D0E0 100%);border:1px solid #8A96B0;border-bottom:none;cursor:pointer;white-space:nowrap;margin-right:2px;margin-bottom:-1px;font-family:var(--font);box-shadow:inset 0 1px 0 rgba(255,255,255,.7);flex-shrink:0;position:relative;text-decoration:none}
.nav-tab:hover{background:linear-gradient(180deg,#EEF2FA 0%,#D8E0F0 100%);color:#0A1A40;text-decoration:none}
.nav-tab.active{background:linear-gradient(180deg,#FFFFFF 0%,#F0F4FF 100%);color:#0A1A40;font-weight:700;border-color:#8A96B0;box-shadow:inset 0 1px 0 #fff,-1px 0 0 rgba(255,255,255,.8);z-index:1}
.nav-tab svg{opacity:.7}
.nav-tab.active svg{opacity:1}
.nav-tab .tab-badge{background:linear-gradient(180deg,#FF4040 0%,#CC0000 100%);color:#fff;font-size:8px;font-weight:700;min-width:13px;height:13px;padding:0 2px;border:1px solid #800000;display:inline-flex;align-items:center;justify-content:center}

#body{display:flex;flex:1;overflow:hidden;position:relative}

#sidebar{width:var(--sidebar-w);flex-shrink:0;background:linear-gradient(180deg,#2E4A82 0%,#1C3060 100%);border-right:2px solid #0A1840;box-shadow:inset -1px 0 0 rgba(255,255,255,.08),2px 0 4px rgba(0,0,0,.3);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;transition:transform .25s ease}
#sidebar::-webkit-scrollbar{display:none}
.sidebar-head{padding:8px;border-bottom:1px solid #0A1840;background:rgba(0,0,0,.15)}
.sidebar-search{position:relative;display:flex;align-items:center}
.sidebar-search input{width:100%;height:22px;background:#0C1E50;border:1px solid #4A6AAA;border-top-color:#1A2A6A;border-left-color:#1A2A6A;color:#C8D8FF;padding:0 24px 0 6px;font-size:10px;outline:none}
.sidebar-search input::placeholder{color:#4A6A9A}
.sidebar-search svg{position:absolute;right:5px;color:#4A6A9A;pointer-events:none}
.sidebar-section{padding-top:6px}
.sidebar-section-label{font-size:9px;font-weight:700;color:#7A9ACC;text-transform:uppercase;letter-spacing:.1em;padding:0 10px 4px}
.sidebar-item{display:flex;align-items:flex-start;padding:6px 10px;cursor:pointer;border-left:3px solid transparent;border-bottom:1px solid rgba(255,255,255,.04);gap:4px;text-decoration:none}
.sidebar-item:hover{background:rgba(255,255,255,.10);border-left-color:#6A9ADD;text-decoration:none}
.sidebar-item-inner{flex:1;min-width:0}
.sidebar-item-num{font-size:10.5px;font-weight:700;color:#A0C0FF;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--font-mono)}
.sidebar-item-meta{font-size:9.5px;color:#6A8AC0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.sidebar-item-date{font-size:9.5px;color:#4A6A9A;margin-top:2px}
.sidebar-item-dot{width:6px;height:6px;background:#4A9AFF;flex-shrink:0;margin-top:4px}
.sidebar-footer{margin-top:auto;padding:8px 10px;border-top:1px solid #0A1840;background:rgba(0,0,0,.15);font-size:9px;color:#4A6A9A;text-align:center}
.sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:250;display:none}
.sidebar-overlay.active{display:block}

#contenu{flex:1;background:#D4D8E0;overflow-y:auto;overflow-x:hidden;padding:14px;min-width:0}

#statusbar{height:var(--statusbar-h);background:linear-gradient(180deg,#E4E8EE 0%,#C8CDD8 100%);border-top:1px solid #8A96B0;display:flex;align-items:center;padding:0 8px;flex-shrink:0;font-size:10px;color:var(--text-sec);overflow:hidden}
.sb-cell{display:flex;align-items:center;gap:4px;padding:0 10px;height:100%;border-right:1px solid #A0AAB8;white-space:nowrap;flex-shrink:0}
.sb-cell:first-child{border-left:1px solid #A0AAB8;padding-left:8px}
.sb-spacer{flex:1}
.sb-dot{width:8px;height:8px;background:linear-gradient(180deg,#40C040 0%,#208020 100%);border:1px solid #106010;flex-shrink:0}
.sb-dot.offline{background:linear-gradient(180deg,#FF4040 0%,#CC0000 100%);border-color:#800000}

#login-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}
.login-modal{background:#ECF0F8;border:2px solid #6A82C0;border-top-color:#A0B4E0;border-left-color:#A0B4E0;box-shadow:3px 3px 10px rgba(0,0,0,.5),inset 0 0 0 1px rgba(255,255,255,.5);width:100%;max-width:360px;overflow:hidden}
.login-modal-head{background:linear-gradient(180deg,#2A5AD0 0%,#1A3A90 50%,#122A70 100%);padding:20px 24px 16px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px;border-bottom:2px solid #0A1840;position:relative}
.login-modal-head::after{content:'';position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.2) 0%,transparent 100%);pointer-events:none}
.login-logo{width:64px}
.login-modal-title{font-size:16px;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5)}
.login-modal-sub{font-size:10.5px;color:rgba(255,255,255,.7)}
.login-modal-body{padding:18px 24px 14px}
.login-modal-footer{padding:0 24px 18px;display:flex;flex-direction:column;gap:8px}

.page-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px;gap:12px;flex-wrap:wrap}
.page-head-left{min-width:0;flex:1}
.breadcrumb{display:flex;align-items:center;gap:4px;font-size:10.5px;color:var(--text-sec);margin-bottom:3px;flex-wrap:wrap}
.breadcrumb span{color:var(--text-sec)}
.breadcrumb a{color:var(--primary);cursor:pointer;text-decoration:none}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb-sep{color:#A0A8B4}
.page-title{font-size:16px;font-weight:700;color:var(--text);line-height:1.2;text-shadow:0 1px 0 rgba(255,255,255,.8);word-break:break-word}
.page-sub{font-size:11px;color:var(--text-sec);margin-top:2px}
.page-head-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap;flex-shrink:0}

.btn{display:inline-flex;align-items:center;gap:5px;height:24px;padding:0 10px;font-family:var(--font);font-size:11px;font-weight:700;cursor:pointer;border:1px solid;text-decoration:none;white-space:nowrap;-webkit-appearance:none;user-select:none}
.btn svg{flex-shrink:0}
.btn-primary{color:#fff;background:linear-gradient(180deg,#3A6AE0 0%,#1A4AAC 50%,#0E3280 100%);border-color:#0A2470;border-top-color:#4A7AF0;border-left-color:#4A7AF0;box-shadow:inset 0 1px 0 rgba(255,255,255,.3),1px 1px 2px rgba(0,0,0,.25);text-shadow:0 1px 2px rgba(0,0,0,.4)}
.btn-primary:hover{background:linear-gradient(180deg,#4A7AF0 0%,#2A5ABE 50%,#1A3A90 100%);color:#fff;text-decoration:none}
.btn-primary:active{background:linear-gradient(180deg,#0E3280 0%,#1A4AAC 100%);box-shadow:inset 1px 1px 3px rgba(0,0,0,.35)}
.btn-secondary{color:var(--text);background:linear-gradient(180deg,#F8F8F8 0%,#E0E4EC 50%,#C8D0DC 100%);border-color:#6A7890;border-top-color:#C0C8D8;border-left-color:#C0C8D8;box-shadow:inset 0 1px 0 rgba(255,255,255,.8),1px 1px 2px rgba(0,0,0,.15)}
.btn-secondary:hover{background:linear-gradient(180deg,#FFFFFF 0%,#EEF2FA 50%,#D8E0EC 100%);color:var(--text);text-decoration:none}
.btn-secondary:active{background:linear-gradient(180deg,#C8D0DC 0%,#E0E4EC 100%)}
.btn-danger{color:#fff;background:linear-gradient(180deg,#E03030 0%,#B40000 50%,#800000 100%);border-color:#600000;border-top-color:#F04040;border-left-color:#F04040;box-shadow:inset 0 1px 0 rgba(255,255,255,.3),1px 1px 2px rgba(0,0,0,.25);text-shadow:0 1px 2px rgba(0,0,0,.4)}
.btn-danger:hover{background:linear-gradient(180deg,#F04040 0%,#CC0000 50%,#900000 100%);color:#fff;text-decoration:none}
.btn-ghost{color:var(--text-sec);background:transparent;border-color:transparent;box-shadow:none}
.btn-ghost:hover{background:linear-gradient(180deg,#F0F4FF 0%,#D8E0F0 100%);border-color:#8A96B0;color:var(--text);text-decoration:none}
.btn-success{color:#fff;background:linear-gradient(180deg,#2A8A2A 0%,#1A6A1A 50%,#0E4E0E 100%);border-color:#0A3A0A;border-top-color:#3A9A3A;border-left-color:#3A9A3A;box-shadow:inset 0 1px 0 rgba(255,255,255,.3),1px 1px 2px rgba(0,0,0,.25)}
.btn-success:hover{background:linear-gradient(180deg,#3A9A3A 0%,#2A7A2A 50%,#1A5A1A 100%);color:#fff;text-decoration:none}
.btn-sm{height:20px;padding:0 8px;font-size:10px}
.btn-lg{height:32px;padding:0 18px;font-size:12px}
.btn-full{width:100%;justify-content:center}
.btn:disabled,.btn.loading{opacity:.55;cursor:not-allowed;pointer-events:none;background:linear-gradient(180deg,#E0E0E0 0%,#C8C8C8 100%) !important;border-color:#A0A0A0 !important;color:#808080 !important;text-shadow:none !important;box-shadow:none !important}

.form-group{display:flex;flex-direction:column;gap:3px;margin-bottom:12px}
.form-group:last-child{margin-bottom:0}
.form-label{font-size:11px;font-weight:700;color:var(--text)}
.form-label .req{color:var(--accent);margin-left:2px}
.form-hint{font-size:10px;color:var(--text-sec)}
.form-input,.form-select,.form-textarea{width:100%;font-family:var(--font);font-size:11px;color:var(--text);background:#FFFFFF;border:1px solid #8A96B0;border-top-color:#4A5A7A;border-left-color:#4A5A7A;outline:none;box-shadow:inset 1px 1px 3px rgba(0,0,0,.15)}
.form-input{height:24px;padding:0 6px}
.form-input:focus{border-color:#2A5AC0;border-top-color:#1A3A90;border-left-color:#1A3A90;background:#FAFCFF}
.form-input[readonly]{background:#EAEEF4;color:var(--text-sec);cursor:default}
.form-input::placeholder{color:#A0AAB8}
.form-select{height:24px;padding:0 24px 0 6px;cursor:pointer;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%234A5A7A'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 7px center;background-color:#FFFFFF}
.form-select:focus{border-color:#2A5AC0}
.form-textarea{padding:5px 6px;resize:vertical;min-height:70px}
.form-textarea:focus{border-color:#2A5AC0}
.form-error-msg{font-size:10px;color:var(--accent);display:none}
.form-group.has-error .form-input,.form-group.has-error .form-select{border-color:var(--accent);background:#FFF0F0}
.form-group.has-error .form-error-msg{display:block}
.pwd-wrap{position:relative}
.pwd-wrap .form-input{padding-right:28px}
.btn-eye{position:absolute;right:4px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#6A7890;padding:2px;line-height:0}

.card{background:var(--card-bg);border:1px solid #8A96B0;border-top-color:#CCD4E4;border-left-color:#CCD4E4;box-shadow:1px 1px 3px rgba(0,0,0,.20),inset 0 0 0 1px rgba(255,255,255,.5);overflow:hidden}
.card-head{padding:6px 12px;border-bottom:1px solid #A0AAC0;display:flex;align-items:center;justify-content:space-between;gap:8px;background:linear-gradient(180deg,#EEF2FA 0%,#D8E0F0 100%);flex-wrap:wrap}
.card-title{font-size:11px;font-weight:700;color:#1A2A4A;display:flex;align-items:center;gap:6px}
.card-title svg{color:var(--primary)}
.card-body{padding:12px}
.card+.card{margin-top:10px}

.form-grid{display:grid;gap:0 16px}
.form-grid-2{grid-template-columns:repeat(2,1fr)}
.form-grid-3{grid-template-columns:repeat(3,1fr)}
.form-grid-4{grid-template-columns:repeat(4,1fr)}
.col-span-2{grid-column:span 2}
.col-span-3{grid-column:span 3}
.col-span-4{grid-column:span 4}

.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table.data-table{width:100%;border-collapse:collapse;font-size:11px;min-width:400px}
table.data-table thead tr{background:linear-gradient(180deg,#EEF2FA 0%,#D8E0F0 100%)}
table.data-table th{padding:6px 10px;text-align:left;font-size:10.5px;font-weight:700;color:#2A3A5A;border-bottom:2px solid #8A96B0;border-right:1px solid #B8C4D8;white-space:nowrap;cursor:pointer;user-select:none;text-shadow:0 1px 0 rgba(255,255,255,.7)}
table.data-table th:hover{color:var(--primary)}
table.data-table td{padding:5px 10px;border-bottom:1px solid #D0D8E8;border-right:1px solid #E0E8F4;color:var(--text);vertical-align:middle}
table.data-table tr:nth-child(even) td{background:#F4F6FA}
table.data-table tr:hover td{background:#E4ECFF}
table.data-table tr:last-child td{border-bottom:none}
.table-mono{font-family:var(--font-mono);font-size:10.5px}

.badge{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;font-size:10px;font-weight:700;white-space:nowrap;border:1px solid}
.badge-info{background:linear-gradient(180deg,#C8E4FF 0%,#A0C8EE 100%);border-color:#5090C0;color:#0A3A6A}
.badge-success{background:linear-gradient(180deg,#C8ECC8 0%,#A0D0A0 100%);border-color:#508050;color:#0A3A0A}
.badge-warning{background:linear-gradient(180deg,#FFE8A8 0%,#F0CC70 100%);border-color:#C09020;color:#5A3A00}
.badge-error{background:linear-gradient(180deg,#FFC8C8 0%,#F0A0A0 100%);border-color:#C05050;color:#5A0A0A}
.badge-gray{background:linear-gradient(180deg,#EAEEF4 0%,#D0D8E4 100%);border-color:#8A96B0;color:#3A4A6A}
.badge-primary{background:linear-gradient(180deg,#C8D8FF 0%,#A0B8F0 100%);border-color:#5068C0;color:#0A1A5A}

.alert{padding:8px 12px;border:1px solid;display:none;align-items:flex-start;gap:7px;font-size:11px;margin-bottom:12px}
.alert.visible{display:flex}
.alert-error{background:linear-gradient(180deg,#FFF0F0 0%,#FFD8D8 100%);border-color:#C08080;color:#600000}
.alert-success{background:linear-gradient(180deg,#F0FFF0 0%,#D8FFD8 100%);border-color:#80C080;color:#004000}
.alert-info{background:linear-gradient(180deg,#F0F8FF 0%,#D8EEFF 100%);border-color:#80A8D0;color:#003060}
.alert-warning{background:linear-gradient(180deg,#FFFCE0 0%,#FFF0B0 100%);border-color:#D0C060;color:#503A00}

#toast-area{position:fixed;bottom:30px;right:16px;display:flex;flex-direction:column;gap:6px;z-index:2000;pointer-events:none}
.toast{background:linear-gradient(180deg,#3A3A4A 0%,#1A1A2A 100%);color:#fff;padding:8px 14px;border:1px solid #6A6A7A;border-top-color:#8A8A9A;box-shadow:2px 2px 6px rgba(0,0,0,.5);font-size:11px;display:flex;align-items:center;gap:7px;min-width:220px;max-width:320px;animation:toastIn .2s ease,toastOut .25s ease 2.75s forwards;pointer-events:all}
.toast-success{background:linear-gradient(180deg,#2A7A2A 0%,#0E4E0E 100%);border-color:#3A8A3A}
.toast-error{background:linear-gradient(180deg,#B42020 0%,#700000 100%);border-color:#D04040}
.toast-info{background:linear-gradient(180deg,#1A5AAA 0%,#0A2A6A 100%);border-color:#2A6ABA}
@keyframes toastIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:none}}
@keyframes toastOut{to{opacity:0;transform:translateX(16px);pointer-events:none}}
.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:sp .75s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}

.section-divider{display:flex;align-items:center;gap:8px;margin:16px 0 12px}
.section-divider-title{font-size:11px;font-weight:700;color:var(--text);white-space:nowrap}
.section-divider-line{flex:1;height:1px;background:#A0AAB8}

.upload-zone{border:2px dashed #8A96B0;padding:16px;text-align:center;cursor:pointer;background:#F0F4FF}
.upload-zone:hover{border-color:var(--primary);background:#E4ECFF}
.upload-zone-text{font-size:11px;color:var(--text-sec);margin-top:5px}
.upload-thumb{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.upload-thumb-item{position:relative;width:56px;height:56px;overflow:hidden;background:#E0E4EC;border:1px solid #8A96B0;display:flex;align-items:center;justify-content:center}
.upload-thumb-item img{width:100%;height:100%;object-fit:cover}
.upload-thumb-del{position:absolute;top:1px;right:1px;background:rgba(0,0,0,.55);color:#fff;border:none;cursor:pointer;width:14px;height:14px;font-size:9px;display:flex;align-items:center;justify-content:center}

.doc-bloc{border:1px solid #8A96B0;margin-bottom:10px;overflow:hidden}
.doc-bloc-head{background:linear-gradient(180deg,#EEF2FA 0%,#D8E0F0 100%);padding:5px 12px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #A0AAC0}
.doc-bloc-title{font-size:11px;font-weight:700;color:#1A2A4A}
.doc-bloc-body{padding:12px}

.pagination{display:flex;align-items:center;gap:3px;justify-content:center;margin-top:12px;flex-wrap:wrap}
.page-btn{width:28px;height:22px;border:1px solid #8A96B0;border-top-color:#CCD4E4;border-left-color:#CCD4E4;background:linear-gradient(180deg,#F0F4FA 0%,#D8E0EC 100%);color:var(--text-sec);font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.page-btn:hover{background:linear-gradient(180deg,#EEF4FF 0%,#D0DCFF 100%);color:var(--text)}
.page-btn.active{background:linear-gradient(180deg,#3A6AE0 0%,#1A4AAC 100%);border-color:#0A2470;color:#fff;font-weight:700}
.page-btn:disabled{opacity:.4;cursor:default}

.signature-zone{border:1px solid #8A96B0;background:#FAFCFF;position:relative;overflow:hidden}
.signature-canvas{display:block;touch-action:none;cursor:crosshair;width:100%;height:130px}
.sig-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:11px;color:#A0AAB8;pointer-events:none}

.module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.module-card{background:linear-gradient(180deg,#FFFFFF 0%,#F0F4FA 100%);border:1px solid #8A96B0;border-top-color:#CCD4E4;border-left-color:#CCD4E4;box-shadow:1px 1px 3px rgba(0,0,0,.18);padding:14px 12px;display:flex;flex-direction:column;align-items:flex-start;gap:8px;cursor:pointer;text-decoration:none;color:var(--text)}
.module-card:hover{background:linear-gradient(180deg,#EEEEFF 0%,#D8E4FF 100%);border-color:#3A6AE0;text-decoration:none;color:var(--text)}
.module-card-icon{width:38px;height:38px;background:linear-gradient(180deg,#EEF4FF 0%,#C8D8F4 100%);border:1px solid #8A9EC0;color:var(--primary);display:flex;align-items:center;justify-content:center}
.module-card-title{font-size:11px;font-weight:700;color:var(--text)}
.module-card-desc{font-size:10.5px;color:var(--text-sec);line-height:1.4}

.profil-header{display:flex;align-items:center;gap:16px;padding:14px;background:linear-gradient(180deg,#FFFFFF 0%,#F0F4FA 100%);border:1px solid #8A96B0;border-top-color:#CCD4E4;border-left-color:#CCD4E4;box-shadow:1px 1px 3px rgba(0,0,0,.18);margin-bottom:10px;flex-wrap:wrap}
.profil-avatar{width:64px;height:64px;background:linear-gradient(180deg,#D0E0FF 0%,#A0B8E8 100%);border:2px solid #6A8AC0;border-top-color:#A0C0E8;color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:700;flex-shrink:0}
.profil-name{font-size:16px;font-weight:700;color:var(--text)}
.profil-grade{font-size:11px;color:var(--text-sec);margin-top:2px}
.profil-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.profil-meta-item{display:flex;align-items:center;gap:4px;font-size:10.5px;color:var(--text-sec)}
.profil-meta-item svg{color:var(--primary)}

.notif-item{padding:9px 12px;border-bottom:1px solid #D0D8E8;display:flex;align-items:flex-start;gap:8px;cursor:pointer}
.notif-item:hover{background:#EEF4FF}
.notif-item.unread{background:#EEF4FF;border-left:3px solid var(--primary)}
.notif-item.unread:hover{background:#E0ECFF}
.notif-dot{width:7px;height:7px;background:var(--primary);flex-shrink:0;margin-top:4px;border:1px solid #0A2470}
.notif-dot.read{background:transparent;border:1px solid #A0AAB8}
.notif-title{font-size:11px;font-weight:700;color:var(--text)}
.notif-body{font-size:10.5px;color:var(--text-sec);margin-top:2px;line-height:1.4}
.notif-time{font-size:10px;color:#8090A8;margin-top:2px}

.empty-state{text-align:center;padding:40px 20px;color:var(--text-sec)}
.empty-state svg{color:#A0AAB8;margin-bottom:10px}
.empty-state-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:5px}
.empty-state-sub{font-size:11px}

.photo-upload-pair{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:8px}
.photo-upload-slot{display:flex;flex-direction:column;gap:4px}
.photo-upload-slot-label{font-size:10px;font-weight:700;color:var(--text-sec);text-transform:uppercase;letter-spacing:.05em}
.photo-upload-slot .upload-zone{min-height:80px;display:flex;flex-direction:column;align-items:center;justify-content:center}
.photo-upload-preview{width:100%;max-height:120px;object-fit:cover;border:1px solid #8A96B0;display:none}
.individu-select-result{border:1px solid #8A96B0;padding:8px 12px;background:#F0F4FA;display:flex;align-items:center;gap:10px;margin-bottom:8px;flex-wrap:wrap}
.individu-select-result-info{flex:1;min-width:0}
.individu-select-result-name{font-size:12px;font-weight:700;color:var(--text)}
.individu-select-result-meta{font-size:10.5px;color:var(--text-sec);margin-top:2px}

.neofind-results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px;margin-top:10px}
.neofind-card{background:#fff;border:1px solid #8A96B0;border-top-color:#CCD4E4;border-left-color:#CCD4E4;padding:10px 14px;cursor:pointer;box-shadow:1px 1px 2px rgba(0,0,0,.12)}
.neofind-card:hover{background:#EEF4FF;border-color:#3A6AE0}
.neofind-card-name{font-size:12px;font-weight:700;color:var(--text)}
.neofind-card-meta{font-size:10.5px;color:var(--text-sec);margin-top:3px;line-height:1.5}

@media(max-width:900px){
  .form-grid-4{grid-template-columns:repeat(2,1fr)}
  .col-span-4{grid-column:span 2}
  .tb-clock{display:none}
}

@media(max-width:700px){
  body{overflow:auto}
  #app{height:auto;min-height:100dvh}
  #body{overflow:visible}
  #contenu{overflow:visible;padding:10px 8px}
  #statusbar .sb-cell:nth-child(3),.sb-spacer,.sb-cell:last-child{display:none}
  .tb-menu-btn{display:flex}
  .tb-sep,.tb-app-badge{display:none}
  .tb-search{max-width:160px}
  #sidebar{position:fixed;top:var(--topbar-h);left:0;bottom:0;z-index:260;transform:translateX(-100%);width:var(--sidebar-w);height:auto;overflow-y:auto}
  #sidebar.sidebar-open{transform:translateX(0)}
  .sidebar-closed{transform:translateX(-100%)}
  .form-grid-3,.form-grid-4{grid-template-columns:repeat(2,1fr)}
  .col-span-3,.col-span-4{grid-column:span 2}
  #navbar{height:auto;flex-wrap:nowrap;overflow-x:auto}
  .module-grid{grid-template-columns:repeat(2,1fr)}
  .profil-header{gap:10px}
}

@media(max-width:480px){
  #topbar{padding:0 8px}
  .tb-search{display:none}
  .tb-user-btn span{display:none}
  #navbar{padding:0 2px}
  .nav-tab{padding:4px 8px 3px;font-size:10px}
  #contenu{padding:8px}
  .form-grid-2,.form-grid-3,.form-grid-4{grid-template-columns:1fr}
  .col-span-2,.col-span-3,.col-span-4{grid-column:span 1}
  .photo-upload-pair{grid-template-columns:1fr}
  .page-title{font-size:14px}
  .module-grid{grid-template-columns:repeat(2,1fr)}
  .login-modal-head{padding:16px 16px 12px}
  .login-modal-body{padding:14px 16px 10px}
  .login-modal-footer{padding:0 16px 16px}
  .form-input,.form-select,.form-textarea{font-size:16px}
  .neofind-results-grid{grid-template-columns:1fr}
  table.data-table{min-width:320px}
}
