:root{--primary: #d71920;--dark: #2c3e50;--light: #ecf0f1}body{margin:0;font-family:Inter,sans-serif;background:#f8f9fa}.app-layout{display:flex;height:100vh;min-height:100dvh}.bottom-tab-nav,.bottom-sheet-overlay{display:none}@media(max-width:768px){.app-layout{flex-direction:column}.sidebar{display:none!important}.main-content{padding-bottom:calc(70px + env(safe-area-inset-bottom))!important;padding-left:1rem!important;padding-right:1rem!important}.bottom-tab-nav{display:flex;position:fixed;bottom:0;left:0;width:100%;background:#fff;border-top:1px solid #eee;padding-bottom:env(safe-area-inset-bottom);z-index:1000;justify-content:space-around;align-items:center;height:60px;box-shadow:0 -2px 10px #0000000d}.nav-item{background:none;border:none;display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;color:#999;font-size:.7rem;padding:8px 0;position:relative}.mobile-badge-wrapper{position:absolute;top:2px;right:50%;margin-right:-25px;z-index:10}.mobile-badge-wrapper span{margin-left:0!important;box-shadow:0 2px 4px #0003}.nav-item.active{color:var(--primary)}.nav-item .icon{font-size:1.2rem;margin-bottom:2px;display:block}.nav-item .label{display:block}.bottom-sheet-overlay{display:flex;position:fixed;inset:0;background:#00000080;z-index:2000;justify-content:center;align-items:flex-end}.bottom-sheet{width:100%;background:#fff;border-radius:20px 20px 0 0;padding:20px;padding-bottom:calc(20px + env(safe-area-inset-bottom));animation:slideUp .3s ease-out;max-height:80vh;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.bottom-sheet-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;border-bottom:1px solid #eee;padding-bottom:15px}.bottom-sheet-header h3{margin:0;font-size:1.2rem}.bottom-sheet-header button{background:#f1f3f5;border:none;border-radius:50%;width:32px;height:32px;font-weight:700;color:#666}.bottom-sheet-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px}.bottom-sheet-grid button{background:#f8f9fa;border:none;border-radius:12px;padding:15px 10px;display:flex;flex-direction:column;align-items:center;gap:8px;font-size:.8rem;color:#333}.bottom-sheet-grid button.active{background:#fff5f5;color:var(--primary);border:1px solid var(--primary)}.bottom-sheet-grid button.logout-btn{background:#fdf2f2;color:#c53030}.bottom-sheet-grid .icon{font-size:1.5rem}}.sidebar{width:250px;background:var(--dark);color:#fff;display:flex;flex-direction:column}.logo{padding:1.5rem;font-size:1.25rem;font-weight:700;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar nav{flex:1;padding:1rem 0}.sidebar button{background:none;border:none;color:#bdc3c7;width:100%;text-align:left;padding:1rem 1.5rem;cursor:pointer;font-size:1rem}.sidebar button:hover,.sidebar button.active{background:#ffffff1a;color:#fff;border-left:4px solid var(--primary)}.main-content{flex:1;padding:2rem;overflow-y:auto}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.project-card{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000000d;cursor:pointer;transition:transform .2s}.project-card:hover{transform:translateY(-5px)}.badge{color:var(--primary);font-weight:700;font-size:.9rem}table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;margin-bottom:2rem}th,td{padding:1rem;text-align:left;border-bottom:1px solid #eee}th{background:#f1f2f6;font-weight:600}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.modal-content{background:#fff;padding:30px;border-radius:12px;width:100%;max-width:500px;box-shadow:0 10px 25px #0003;transform:translateY(0);animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-content h3{margin-top:0;margin-bottom:20px;color:#2d3748;font-size:1.5rem;border-bottom:2px solid #edf2f7;padding-bottom:10px}.mobile-card{background:#fff;border-radius:12px;padding:16px;margin-bottom:16px;display:flex;flex-direction:column;gap:12px}.card-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #f0f0f0;padding-bottom:8px}.card-ref{font-weight:700;color:var(--primary)}.card-date{font-size:.85rem;color:#888}.card-body{display:flex;flex-direction:column;gap:4px}.card-supplier{font-weight:600;font-size:1.05rem}.card-footer{display:flex;justify-content:space-between;align-items:flex-end;margin-top:4px}.card-amount{font-size:1.25rem;font-weight:700;color:#2d3748}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#4a5568;font-size:.9rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #cbd5e0;border-radius:6px;font-size:1rem;transition:border-color .2s;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #d719201a}.form-group textarea{min-height:100px;resize:vertical}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:30px;padding-top:20px;border-top:1px solid #edf2f7}.modal-actions button{min-width:100px}.status-badge.validated{background:#bee3f8;color:#2a4365}.status-badge.released{background:#c6f6d5;color:#22543d}.status-badge.draft,.status-badge.brouillon{background:#fed7d7;color:#822727;border:1px solid #feb2b2}.status.validated{color:green;font-weight:700}.status.draft,.status.brouillon{color:orange;font-weight:700}.header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.cta-btn{width:auto;padding:.8rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600;transition:opacity .2s}.cta-btn:hover{opacity:.9}.cta-btn.safe{background:#48bb78}.btn-secondary{background:#e2e8f0;color:#2d3748;border:none;border-radius:4px;padding:.8rem 1.5rem;cursor:pointer;font-weight:600;transition:background .2s}.btn-secondary:hover{background:#cbd5e0}.back-btn{background:none;color:#666;width:auto;margin-bottom:1rem;padding:0}.login-container{height:100vh;display:flex;justify-content:center;align-items:center}.login-form{background:#fff;padding:2rem;border-radius:8px;text-align:center}.login-form input{width:100%;margin-bottom:1rem;padding:.5rem}.login-form button{width:100%;padding:.5rem;background:var(--primary);color:#fff;border:none}.kpi-container{position:relative;display:inline-block;cursor:help;padding:5px;font-size:1.2rem}.kpi-container .kpi-text{visibility:hidden;width:180px;background-color:#333;color:#fff;text-align:center;border-radius:6px;padding:8px;position:absolute;z-index:100;bottom:125%;left:50%;margin-left:-90px;opacity:0;transition:opacity .3s;font-size:.8rem;font-weight:400;line-height:1.2;box-shadow:0 4px 6px #0000001a}.kpi-container .kpi-text:after{content:"";position:absolute;top:100%;left:50%;margin-left:-5px;border-width:5px;border-style:solid;border-color:#333 transparent transparent transparent}.kpi-container:hover .kpi-text{visibility:visible;opacity:1}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}.alert-pulse{animation:pulse 1s infinite ease-in-out}.kpi-row-red{background-color:#fff5f5!important}.kpi-row-orange{background-color:#fffaf0!important}.kpi-row-green{background-color:#f0fff4!important}.kpi-row-red:hover{background-color:#fed7d7!important}.kpi-row-orange:hover{background-color:#feebc8!important}.kpi-row-green:hover{background-color:#c6f6d5!important}.multi-select-container{position:relative;display:inline-block;min-width:180px}.multi-select-button{width:100%;padding:.75rem 1rem;background:#fff;border:1px solid #ced4da;border-radius:4px;text-align:left;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-size:.9rem;transition:border-color .2s}.multi-select-button:hover{border-color:var(--primary)}.multi-select-dropdown{position:absolute;top:100%;left:0;z-index:1000;width:280px;background:#fff;border:1px solid #ced4da;border-radius:4px;box-shadow:0 4px 12px #00000026;margin-top:5px;padding:.5rem;max-height:400px;overflow-y:auto}.multi-select-search{width:100%;padding:.6rem;margin-bottom:.5rem;border:1px solid #eee;border-radius:4px;box-sizing:border-box;font-size:.85rem}.multi-select-options{display:flex;flex-direction:column}.multi-select-option{padding:.5rem;display:flex;align-items:center;cursor:pointer;border-radius:4px;font-size:.85rem;-webkit-user-select:none;user-select:none}.multi-select-option:hover{background:#f8f9fa}.multi-select-option input{margin-right:.75rem;cursor:pointer}.multi-select-option.all{border-bottom:1px solid #eee;margin-bottom:.4rem;padding-bottom:.6rem}.arrow{border:solid #666;border-width:0 2px 2px 0;display:inline-block;padding:3px;margin-left:10px;transition:transform .2s}.up{transform:rotate(-135deg)}.down{transform:rotate(45deg)}.filters-bar{display:flex;align-items:flex-end;flex-wrap:wrap;background:#fff;padding:1.5rem;border-radius:8px;margin-bottom:1.5rem;box-shadow:0 2px 4px #0000000d;gap:1.25rem}.filter-group{display:flex;flex-direction:column;min-width:220px}.filter-label{font-size:.75rem;font-weight:700;color:#888;margin-bottom:.6rem;text-transform:uppercase;letter-spacing:.05em}.results-counter{margin-left:auto;font-size:.95rem;color:#2c3e50;font-weight:600;align-self:center;background:#f1f3f5;padding:.5rem 1rem;border-radius:20px}.loading-indicator{display:inline-block;width:20px;height:20px;border:2px solid rgba(0,0,0,.1);border-radius:50%;border-top-color:var(--primary);animation:spin 1s ease-in-out infinite;vertical-align:middle;margin-right:10px}@keyframes spin{to{transform:rotate(360deg)}}.pdf-viewer-modal{width:95vw;height:95vh;background:#525659;display:flex;flex-direction:column;box-shadow:0 10px 30px #00000080;animation:slideIn .2s ease-out}.registry-table{table-layout:fixed;width:100%}.cell-truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.cell-stacked{display:flex;flex-direction:column;gap:2px;line-height:1.2}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem;color:#718096}.font-mono{font-family:Roboto Mono,monospace}.action-menu-item{display:flex;align-items:center;width:100%;padding:8px 12px;border:none;background:none;text-align:left;cursor:pointer;font-size:.85rem;color:#2d3748;transition:background .2s;box-sizing:border-box}.action-menu-item:hover{background:#f7fafc;color:var(--primary)}.action-menu-item .icon{margin-right:8px;width:20px;text-align:center;font-size:1rem}.sticky-tabs{position:sticky;top:0;z-index:900;background:#fff;transition:all .3s ease}.mobile-fab{position:fixed;bottom:80px;right:20px;width:56px;height:56px;border-radius:50%;background:var(--primary);color:#fff;display:flex!important;align-items:center;justify-content:center;font-size:24px;box-shadow:0 4px 6px #0000004d;border:none;z-index:1000;cursor:pointer;transition:transform .2s}.mobile-fab:active{transform:scale(.95)}.chart-scroll-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.filter-pill-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#edf2f7;color:#4a5568;border:1px solid #cbd5e0;border-radius:20px;font-size:.9rem;font-weight:600;cursor:pointer}.filter-pill-btn.active{background:#ebf8ff;color:#2b6cb0;border-color:#4299e1}@media(max-width:768px){.tabs-nav{overflow-x:auto;white-space:nowrap;border-radius:0;margin-bottom:0!important;border-bottom:1px solid #eee}.tabs-nav button{padding:12px 16px!important;flex:none!important}.project-header h2{font-size:1.25rem}.desktop-actions{display:none}}.table-container{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:1rem;border-radius:8px}.table-container.shadow{box-shadow:0 2px 4px #0000000d}.collapsed-on-scroll{position:static!important;transition:transform .3s ease}.mobile-fab{z-index:1100}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{pointer-events:auto;background:#fff;padding:12px 16px;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;align-items:flex-start;justify-content:space-between;min-width:300px;max-width:450px;animation:slideIn .3s ease-out;border-left:5px solid #ccc;font-family:Inter,sans-serif}.toast.toast-success{border-left-color:#48bb78}.toast.toast-error{border-left-color:#f56565}.toast.toast-warning{border-left-color:#ed8936}.toast.toast-info{border-left-color:#4299e1}.toast-content{display:flex;align-items:center;gap:12px;font-size:.95rem;color:#2d3748;line-height:1.4}.toast-message{font-weight:500}.toast-close{background:none;border:none;font-size:1.25rem;color:#a0aec0;cursor:pointer;margin-left:10px;padding:0;line-height:1;transition:color .2s}.toast-close:hover{color:#4a5568}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}
