:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top,#1e293b,#020617 55%);color:#f1f5f9}#root{min-height:100vh}button{border-radius:999px;border:none;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;font-family:inherit;background:#1d4ed8;color:#fff;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 15px 30px #1d4ed84d}@media(min-width:641px)and (max-width:1024px){button{padding:.85rem 1.75rem;font-size:1.05rem}}button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}button:hover:not(:disabled){transform:translateY(-2px)}button:focus-visible{outline:3px solid #93c5fd;outline-offset:2px}@media(min-width:641px)and (max-width:1024px){button,.route-nav a,.link-button{min-height:44px}.route-nav .nav-logout{min-width:44px;min-height:44px}}.app-shell{width:min(960px,100%);margin:0 auto;padding:3rem 1.5rem 4rem;display:flex;flex-direction:column;gap:1.5rem}@media(min-width:641px)and (max-width:1024px)and (orientation:portrait){.app-shell{width:min(800px,100%);padding:2.5rem 2rem 3.5rem}}.panel{background:#fff;border-radius:1.25rem;padding:1.75rem;box-shadow:0 15px 30px #0f172a14;display:flex;flex-direction:column;gap:1rem}.route-nav{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;padding:1rem;background:#f8fafc;border-radius:1rem;border:1px solid #e2e8f0;margin-bottom:1rem}.route-nav a{text-decoration:none;padding:.45rem 1rem;border-radius:999px;font-weight:600;color:#1d4ed8;background:#1d4ed81f;transition:background .2s ease}.route-nav a.active{background:#1d4ed8;color:#fff}.route-nav a:hover{background:#1d4ed840;color:#0f172a}.route-nav .nav-logout{padding:.45rem;border-radius:999px;font-weight:600;color:#dc2626;background:#dc26261f;border:none;cursor:pointer;transition:background .2s ease;font-size:inherit;font-family:inherit;display:flex;align-items:center;justify-content:center;width:2rem;height:2rem}.route-nav .nav-logout:hover{background:#dc262640;color:#991b1b}.route-nav .nav-user-name{margin-left:auto;margin-right:.75rem;font-weight:600;color:#0f172a;padding:.45rem 0}.auth-panel{width:450px;margin:0 auto;border:1px solid #e2e8f0}.panel-header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.panel-header h2{margin:0;font-size:1.35rem}.hint{padding:.2rem .65rem;border-radius:.65rem;font-size:.85rem;background:#e0e7ff;color:#312e81;text-transform:capitalize}.auth-tabs{display:inline-flex;gap:.5rem;padding:.3rem;border-radius:999px;background:#f1f5f9}.auth-tabs button{background:transparent;border:none;padding:.35rem .95rem;border-radius:999px;font-weight:600;color:#475569;cursor:pointer}.auth-tabs button.active{background:#1d4ed8;color:#fff}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-form label{display:flex;flex-direction:column;gap:.3rem;font-weight:600;color:#0f172a}.auth-form input{border:1px solid #cbd5f5;border-radius:.75rem;padding:.65rem .85rem;font-size:1rem}@media(min-width:641px)and (max-width:1024px){.auth-form input{padding:.75rem 1rem;font-size:1.05rem}.auth-form label{font-size:1rem}}.auth-form button{margin-top:.5rem}.api-url{margin:0;font-size:.95rem;color:#475569}.account-card{display:flex;flex-direction:column;gap:1rem}.account-greeting{margin:0;font-size:1.1rem;font-weight:600}.account-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem;margin:0}.account-meta dt{margin:0;font-size:.85rem;color:#94a3b8;text-transform:uppercase}.account-meta dd{margin:.2rem 0 0;font-weight:600;color:#0f172a}.error{margin:0;color:#dc2626;font-weight:600}.protected-warning{align-items:flex-start}.link-button{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;border-radius:999px;padding:.65rem 1.5rem;font-weight:600;text-decoration:none;border:1px solid transparent;background:#1d4ed8;color:#fff;cursor:pointer}.link-button.ghost-link{background:transparent;border-color:#cbd5f5;color:#1d4ed8}.dashboard-panel{border:1px solid #e2e8f0}.dashboard-intro{margin:0;color:#475569}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.dashboard-grid article{border:1px solid #e2e8f0;border-radius:1rem;padding:1rem;background:#f8fafc;display:flex;flex-direction:column;gap:.5rem}.dashboard-grid h3{margin:0;font-size:1rem;color:#334155}.stat-value{margin:0;font-size:2rem;font-weight:700;color:#0f172a}.info-panel .info-list{margin:0;padding-left:1.25rem;display:flex;flex-direction:column;gap:.75rem;color:#475569}.panel-value{margin:0;font-size:clamp(3rem,10vw,5rem);font-weight:700;text-align:center}.actions{display:flex;flex-wrap:wrap;gap:.75rem}.actions button{flex:1;min-width:150px}button.ghost{background:transparent;border:1px dashed #cbd5f5;color:#475569;min-width:fit-content}.note-form{display:flex;gap:.75rem;flex-wrap:wrap}.note-form input{flex:1;min-width:220px;border:1px solid #e2e8f0;border-radius:.75rem;padding:.75rem 1rem;font-size:1rem}.note-form button{min-width:140px}.note-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem}.note-list li{display:flex;align-items:center;justify-content:space-between;gap:.85rem;padding:.75rem 1rem;border-radius:.9rem;background:#f8fafc}.note-list span{flex:1;text-align:left}.empty{margin:0;color:#94a3b8}small{color:#64748b}.modal-overlay{position:fixed;inset:0;background:#0f172abf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:1.25rem;padding:2rem;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px #0f172a40;animation:slideUp .3s ease;position:relative}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h3{margin:0;font-size:1.5rem;color:#0f172a}.modal-close{background:transparent;border:none;font-size:1.5rem;color:#64748b;cursor:pointer;padding:.25rem;line-height:1;transition:color .2s ease;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:.5rem}.modal-close:hover{color:#0f172a;background:#f1f5f9}.modal-form{display:flex;flex-direction:column;gap:1rem}.modal-form label{display:flex;flex-direction:column;gap:.3rem;font-weight:600;color:#0f172a}.modal-form input,.modal-form textarea,.modal-form select{border:1px solid #cbd5f5;border-radius:.75rem;padding:.65rem .85rem;font-size:1rem;font-family:inherit}@media(min-width:641px)and (max-width:1024px){.modal-form input,.modal-form textarea,.modal-form select{padding:.75rem 1rem;font-size:1.05rem}}.modal-form textarea{resize:vertical;min-height:80px}.modal-actions{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap}.modal-actions button{flex:1;min-width:120px}@media(min-width:641px)and (max-width:1024px){.app-shell{width:min(900px,100%);padding:3rem 2rem 4rem}.panel{padding:2rem}.auth-panel{width:500px}.panel-header h2{font-size:1.5rem}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.25rem}.dashboard-grid article{padding:1.25rem}.account-meta{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.modal-content{max-width:600px;padding:2.5rem}.route-nav{padding:1.25rem;gap:.75rem}.route-nav a{padding:.5rem 1.25rem;font-size:1rem}.actions button{min-width:180px}.note-form input{min-width:280px}}@media(max-width:640px){.app-shell{padding:2rem 1rem 3rem}.panel,.hero{padding:1.5rem}.route-nav{justify-content:center}.auth-tabs{width:100%;justify-content:space-between}.actions button{min-width:unset;flex:1 1 100%}.modal-content{padding:1.5rem;max-width:100%}.modal-actions{flex-direction:column}.modal-actions button{width:100%}}.projet-actions{display:flex;justify-content:flex-start;margin-bottom:1.5rem}.btn-add-project{padding:.65rem 1.5rem;border-radius:999px;font-weight:600;border:none;background:#1d4ed8;color:#fff;cursor:pointer;transition:background .2s ease;font-size:1rem}.btn-add-project:hover:not(:disabled){background:#1e40af}.btn-add-project:disabled{opacity:.5;cursor:not-allowed}.projects-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}@media(max-width:1200px){.projects-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:900px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.projects-grid{grid-template-columns:1fr}}.project-card{border:1px solid #e2e8f0;border-radius:1rem;padding:1.5rem;background:#fff;display:flex;flex-direction:column;gap:.75rem;transition:box-shadow .2s ease,transform .2s ease}.project-card:hover{box-shadow:0 10px 25px #0f172a1a;transform:translateY(-2px)}.project-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.project-card-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#0f172a;flex:1}.project-card-actions{display:flex;gap:.5rem}.btn-edit,.btn-delete{background:transparent;border:none;font-size:1.2rem;cursor:pointer;padding:.25rem;border-radius:.5rem;transition:background .2s ease;line-height:1}.btn-edit:hover{background:#e0e7ff}.btn-delete:hover{background:#fee2e2}.project-type{margin:0;font-size:.9rem;font-weight:600;color:#1d4ed8;text-transform:uppercase;letter-spacing:.05em}.project-description{margin:0;color:#475569;line-height:1.6;flex:1}.project-meta{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem;padding-top:.75rem;border-top:1px solid #e2e8f0}.project-users{display:flex;flex-direction:column;gap:.25rem}.project-users strong{font-size:.85rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.project-users span{font-size:.9rem;color:#0f172a}.project-dates{display:flex;flex-direction:column;gap:.25rem}.project-dates small{font-size:.8rem;color:#94a3b8}.projet-panel{border:1px solid #e2e8f0}.project-detail-panel{border:1px solid #e2e8f0;overflow:hidden}.project-detail-header{background:linear-gradient(135deg,#667eea,#764ba2);margin:-1.75rem -1.75rem 2rem;padding:2.5rem 1.75rem;color:#fff}.project-detail-header-content{display:flex;flex-direction:column;gap:1rem;align-items:flex-start}.project-detail-title{margin:0;font-size:2rem;font-weight:700;color:#fff;line-height:1.2}.project-detail-badge{display:inline-block;padding:.5rem 1rem;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:999px;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border:1px solid rgba(255,255,255,.3)}.project-detail-content{display:flex;flex-direction:column;gap:2rem}.project-detail-section{padding:1.5rem;background:#f8fafc;border-radius:.75rem;border:1px solid #e2e8f0}.project-detail-section-title{margin:0 0 1rem;font-size:1.125rem;font-weight:600;color:#0f172a;text-transform:uppercase;letter-spacing:.05em;font-size:.875rem}.project-detail-description{margin:0;color:#475569;line-height:1.7;font-size:1rem}.project-detail-users-list{display:flex;flex-direction:column;gap:.75rem}.project-detail-user-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#fff;border-radius:.5rem;border:1px solid #e2e8f0;transition:transform .2s ease,box-shadow .2s ease}.project-detail-user-item:hover{transform:translate(4px);box-shadow:0 4px 12px #0f172a14}.project-detail-user-avatar{width:2.5rem;height:2.5rem;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;flex-shrink:0}.project-detail-user-name{font-size:.95rem;color:#0f172a;font-weight:500}.project-detail-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.project-detail-info-item{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:#fff;border-radius:.5rem;border:1px solid #e2e8f0}.project-detail-info-label{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.project-detail-info-value{font-size:.95rem;color:#0f172a;font-weight:500}.project-detail-actions{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e2e8f0}.project-detail-back-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#1d4ed8;color:#fff;border:none;border-radius:.5rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s ease,transform .2s ease;font-family:inherit}.project-detail-back-button:hover{background:#1e40af;transform:translateY(-2px);box-shadow:0 4px 12px #1d4ed84d}.project-detail-back-button:active{transform:translateY(0)}.project-detail-back-icon{font-size:1.2rem;line-height:1}@media(max-width:640px){.project-detail-header{padding:2rem 1.5rem}.project-detail-title{font-size:1.5rem}.project-detail-section{padding:1.25rem}.project-detail-info-grid{grid-template-columns:1fr}}.project-detail-documents{display:flex;flex-direction:column;gap:1rem}.project-detail-document-item{padding:1.25rem;background:#fff;border-radius:.75rem;border:1px solid #e2e8f0;transition:box-shadow .2s ease,transform .2s ease}.project-detail-document-item:hover{box-shadow:0 4px 12px #0f172a14;transform:translateY(-2px)}.project-detail-document-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.75rem}.project-detail-document-header h4{margin:0;font-size:1.125rem;font-weight:600;color:#0f172a;flex:1}.project-detail-document-category{padding:.375rem .75rem;background:#f1f5f9;border-radius:999px;font-size:.75rem;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.project-detail-document-description{margin:0 0 .75rem;color:#64748b;line-height:1.6;font-size:.9375rem}.project-detail-document-meta{margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid #f1f5f9}.project-detail-document-meta small{color:#94a3b8;font-size:.8125rem}.project-detail-document-actions{display:flex;gap:.75rem;flex-wrap:wrap}.project-detail-document-actions .link-button{padding:.5rem 1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;color:#1d4ed8;text-decoration:none;font-size:.875rem;font-weight:500;transition:all .2s ease;display:inline-flex;align-items:center;gap:.375rem}.project-detail-document-actions .link-button:hover{background:#eff6ff;border-color:#3b82f6;color:#2563eb;transform:translateY(-1px);box-shadow:0 2px 4px #3b82f626}@media(max-width:640px){.project-detail-document-header{flex-direction:column;align-items:flex-start}.project-detail-document-actions{flex-direction:column}.project-detail-document-actions .link-button{width:100%;justify-content:center}}.upload-section{display:flex;flex-direction:column;gap:.75rem}.upload-dropzone{border:2px dashed #cbd5e1;border-radius:.5rem;padding:2rem;text-align:center;background:#f8fafc;cursor:pointer;transition:all .2s ease;min-height:120px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem}.upload-dropzone:hover{border-color:#3b82f6;background:#eff6ff}.upload-dropzone.dragging{border-color:#3b82f6;background:#dbeafe;transform:scale(1.02)}.upload-dropzone.has-file{border-color:#10b981;background:#ecfdf5}.upload-file-info{display:flex;align-items:center;gap:.75rem;font-weight:500;color:#059669}.remove-file{background:#ef4444;color:#fff;border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:background .2s ease}.remove-file:hover{background:#dc2626}.file-input-label{display:inline-block;padding:.5rem 1rem;background:#3b82f6;color:#fff;border-radius:.375rem;cursor:pointer;font-weight:500;transition:background .2s ease}.file-input-label:hover{background:#2563eb}.upload-alternative{text-align:center;color:#64748b;font-size:.875rem;margin:.5rem 0}.category-section{display:flex;flex-direction:column;gap:.5rem}.category-controls{display:flex;gap:.5rem;margin-bottom:.5rem}.category-mode-btn{flex:1;padding:.5rem 1rem;border:2px solid #e2e8f0;background:#fff;border-radius:.375rem;cursor:pointer;font-weight:500;transition:all .2s ease;color:#64748b}.category-mode-btn:hover{border-color:#3b82f6;color:#3b82f6}.category-mode-btn.active{border-color:#3b82f6;background:#eff6ff;color:#3b82f6}.document-viewer{margin:0;border:none;border-top:1px solid #f1f5f9;border-radius:0;overflow:hidden;background:#fff}.document-pdf-viewer{display:flex;flex-direction:column;padding:1.5rem}.pdf-iframe{width:100%;min-height:600px;border:none;background:#fff}.document-image-viewer{display:flex;flex-direction:column}.document-image{width:100%;max-height:500px;object-fit:contain;background:#fff;display:block}.document-video-viewer,.document-audio-viewer{display:flex;flex-direction:column;padding:1rem;background:#fff}.document-video{width:100%;max-height:500px;background:#000}.document-audio{width:100%}.document-other-viewer{padding:1.5rem;background:#fff}.document-file-info{display:flex;align-items:center;justify-content:flex-start;gap:.75rem;margin-bottom:1.25rem}.file-icon{font-size:1.75rem;flex-shrink:0}.file-name{font-weight:500;color:#1e293b;word-break:break-all;font-size:.9375rem;line-height:1.4}.document-viewer-actions{display:flex;gap:.625rem;justify-content:flex-start;background:#fafbfc;border-top:1px solid #f1f5f9;flex-wrap:wrap}.viewer-link{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.125rem;background:#fff;border:1.5px solid #e2e8f0;border-radius:.5rem;text-decoration:none;color:#3b82f6;font-weight:600;font-size:.875rem;transition:all .2s ease;box-shadow:0 1px 2px #0000000d}.viewer-link:hover{background:#eff6ff;border-color:#3b82f6;color:#2563eb;box-shadow:0 2px 4px #3b82f626;transform:translateY(-1px)}@media(max-width:768px){.pdf-iframe{min-height:400px}.document-viewer-actions{flex-direction:column}.viewer-link{width:100%;justify-content:center}}.doc-panel{color:#0f172a}.doc-panel .document-card{color:#0f172a;border:1px solid #e2e8f0;border-radius:1rem;padding:0;background:#fff;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 1px 3px #0000000d;transition:box-shadow .2s ease,transform .2s ease}.doc-panel .document-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.doc-panel .document-card-header{padding:1.5rem 1.5rem 1rem;border-bottom:1px solid #f1f5f9;background:linear-gradient(to bottom,#fafbfc,#fff)}.doc-panel .document-card-header h3{color:#0f172a;margin:0;font-size:1.35rem;font-weight:700;letter-spacing:-.02em;line-height:1.3}.doc-panel .document-description{color:#64748b;margin:0;padding:0 1.5rem;line-height:1.6;font-size:.95rem}.doc-panel .document-category,.doc-panel .document-project{padding:0 1.5rem;margin:0;font-size:.875rem;color:#475569;display:flex;align-items:center;gap:.5rem}.doc-panel .document-category{background:#f8fafc;border-top:1px solid #f1f5f9;border-bottom:1px solid #f1f5f9}.doc-panel .document-category strong,.doc-panel .document-project strong{color:#334155;font-weight:600;text-transform:uppercase;font-size:.75rem;letter-spacing:.05em}.doc-panel .document-meta{padding:0 1.5rem;color:#94a3b8;font-size:.8125rem;border-bottom:1px solid #f1f5f9;background:transparent}.doc-panel .document-meta small{color:#94a3b8;display:block;line-height:1.5}.doc-panel .document-dates{display:flex;flex-direction:column;gap:.25rem}.doc-panel .doc-actions{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.doc-panel .doc-filters{display:flex;gap:1rem;flex-wrap:wrap;flex:1}.doc-panel .doc-filters label{display:flex;flex-direction:column;gap:.5rem;color:#0f172a}.doc-panel .doc-filters label span{font-weight:500;color:#0f172a;font-size:.875rem}.doc-panel .doc-filters select{padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:.5rem;background:#fff;color:#0f172a;font-size:.875rem}.doc-panel .btn-add-doc{padding:.65rem 1.5rem;border-radius:999px;font-weight:600;border:none;background:#1d4ed8;color:#fff;cursor:pointer;transition:background .2s ease;font-size:1rem;white-space:nowrap}.doc-panel .btn-add-doc:hover:not(:disabled){background:#1e40af}.doc-panel .btn-add-doc:disabled{opacity:.5;cursor:not-allowed}.doc-panel .documents-grid{display:flex;flex-direction:column;gap:1.5rem}.doc-panel .document-card{width:100%;max-width:100%}@media(max-width:768px){.doc-panel .doc-actions{flex-direction:column;align-items:stretch}.doc-panel .doc-filters{width:100%}}.document-viewer-actions .btn-edit,.document-viewer-actions .btn-delete{background:#fff;border:1.5px solid #e2e8f0;color:#3b82f6;padding:.625rem 1.125rem;border-radius:.5rem;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;font-family:inherit;box-shadow:0 1px 2px #0000000d}.document-viewer-actions .btn-edit:hover{background:#eff6ff;border-color:#3b82f6;color:#2563eb;box-shadow:0 2px 4px #3b82f626;transform:translateY(-1px)}.document-viewer-actions .btn-delete{color:#ef4444;border-color:#fee2e2}.document-viewer-actions .btn-delete:hover{background:#fef2f2;border-color:#ef4444;color:#dc2626;box-shadow:0 2px 4px #ef444426;transform:translateY(-1px)}
