@keyframes slideInRight{0%{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}.login-container{min-height:calc(100vh - 200px);display:flex;align-items:center;justify-content:center;padding:2rem 20px;position:relative}.login-box{background:var(--bg-secondary);border-radius:var(--border-radius-lg);padding:3rem;max-width:450px;width:100%;box-shadow:0 8px 30px rgba(0,0,0,.4);border:1px solid var(--border-color);animation:fadeInUp .6s ease-out}.login-header{text-align:center;margin-bottom:2rem}.login-header h2{font-size:2rem;margin-bottom:.5rem;background:linear-gradient(135deg,var(--text-primary) 0,var(--accent-color) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-header p{color:var(--text-secondary);font-size:.95rem}.login-logo{width:80px;height:80px;margin:0 auto 1.5rem;background:linear-gradient(135deg,rgba(107,70,193,.2),rgba(107,70,193,.05));border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--accent-color);position:relative;animation:pulse 2s infinite;box-shadow:0 0 30px rgba(107,70,193,.3)}.login-logo img{width:60px;height:60px;object-fit:contain}.password-input-wrapper{position:relative}.password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-light);cursor:pointer;padding:.5rem;transition:var(--transition)}.password-toggle:hover{color:var(--text-primary)}.btn-login{width:100%;padding:.75rem 2rem;background:linear-gradient(135deg,var(--primary-color),#f0f0f0);color:var(--secondary-color);border:none;border-radius:var(--border-radius);cursor:pointer;font-weight:600;font-size:1rem;transition:all .3s ease;margin-top:.5rem;box-shadow:0 4px 15px hsla(0,0%,100%,.2);position:relative;overflow:hidden}.btn-login:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.3),transparent);transition:left .5s}.btn-login:hover:before{left:100%}.btn-login:hover{background:linear-gradient(135deg,#f0f0f0,var(--primary-color));transform:translateY(-2px);box-shadow:0 6px 20px hsla(0,0%,100%,.3)}.admin-container{max-width:1200px;margin:0 auto;padding:calc(100px + 2rem) 20px 2rem;min-height:calc(100vh - 200px);position:relative;animation:fadeInUp .6s ease-out}.admin-header{margin-bottom:3rem;padding-bottom:1.5rem;border-bottom:2px solid var(--border-color);position:relative;animation:slideInRight .6s ease-out}.admin-header h1{font-size:2.5rem;margin-bottom:.5rem;color:var(--text-primary);background:linear-gradient(135deg,var(--text-primary) 0,var(--accent-color) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.admin-header p{color:var(--text-secondary);font-size:1rem}.admin-section{background:var(--bg-secondary);border-radius:var(--border-radius-lg);padding:2rem;margin-bottom:2rem;box-shadow:0 4px 20px rgba(0,0,0,.3);border:1px solid var(--border-color);position:relative;overflow:hidden;transition:all .3s ease;animation:fadeInUp .6s ease-out}.admin-section:hover{transform:translateY(-5px);box-shadow:0 8px 30px rgba(107,70,193,.2);border-color:rgba(107,70,193,.3)}.admin-section h2{font-size:1.5rem;margin-bottom:1.5rem;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.admin-section h2 i{color:var(--accent-color)}.form-group label{display:block;margin-bottom:.5rem;color:var(--text-primary);font-weight:500;font-size:.9rem}.form-group select{width:100%;padding:.75rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-primary);font-family:Inter,sans-serif;font-size:.95rem;transition:var(--transition)}.form-group select:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px rgba(107,70,193,.2)}.tags-input{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.tag-input-item{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .8rem;background:linear-gradient(135deg,var(--bg-primary),rgba(107,70,193,.1));border:1px solid rgba(107,70,193,.3);border-radius:var(--border-radius);color:var(--text-primary);font-size:.85rem}.tag-input-item .remove-tag{cursor:pointer;color:var(--text-light);transition:var(--transition)}.tag-input-item .remove-tag:hover{color:var(--text-primary)}.tag-input-wrapper{display:flex;gap:.5rem}.tag-input-wrapper input{flex:1 1}.btn-add-tag{padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--accent-color),#5a3aa8);color:#fff;border:none;border-radius:var(--border-radius);cursor:pointer;font-weight:500;transition:all .3s ease}.btn-add-tag:hover{background:linear-gradient(135deg,#5a3aa8,var(--accent-color));transform:translateY(-2px)}.form-actions{display:flex;gap:1rem;margin-top:2rem}.btn-submit{padding:.75rem 2rem;background:linear-gradient(135deg,var(--primary-color),#f0f0f0);color:var(--secondary-color);border:none;border-radius:var(--border-radius);cursor:pointer;font-weight:600;font-size:1rem;transition:all .3s ease}.btn-submit:hover{background:linear-gradient(135deg,#f0f0f0,var(--primary-color));transform:translateY(-2px)}.btn-reset{padding:.75rem 2rem;background:transparent;color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--border-radius);cursor:pointer;font-weight:500;font-size:1rem;transition:var(--transition)}.btn-reset:hover{background:var(--bg-secondary);border-color:var(--text-light)}.projects-list{display:grid;grid-gap:1rem;gap:1rem}.project-item{background:linear-gradient(135deg,var(--bg-primary),rgba(107,70,193,.05));border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1.5rem;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;transition:all .3s ease}.project-item:hover{border-color:var(--accent-color);box-shadow:0 8px 25px rgba(107,70,193,.2);transform:translateY(-5px)}.project-item-info h3{font-size:1.1rem;margin-bottom:.5rem;color:var(--text-primary)}.project-item-info p{font-size:.9rem;color:var(--text-secondary);margin-bottom:.5rem}.project-item-meta{display:flex;gap:1rem;flex-wrap:wrap;margin-top:.5rem}.project-item-meta span{font-size:.85rem;color:var(--text-light);padding:.25rem .5rem;background:linear-gradient(135deg,var(--bg-secondary),rgba(107,70,193,.1));border:1px solid rgba(107,70,193,.2);border-radius:var(--border-radius)}.project-item-actions{display:flex;gap:.5rem}.btn-delete,.btn-edit{padding:.5rem 1rem;border:none;border-radius:var(--border-radius);cursor:pointer;font-size:.85rem;font-weight:500;transition:var(--transition)}.btn-edit{background:linear-gradient(135deg,var(--accent-color),#5a3aa8);color:#fff}.btn-edit:hover{background:linear-gradient(135deg,#5a3aa8,var(--accent-color));transform:translateY(-2px)}.btn-delete{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff}.btn-delete:hover{background:linear-gradient(135deg,#b91c1c,#dc2626);transform:translateY(-2px)}.alert{padding:1rem;border-radius:var(--border-radius);margin-bottom:1rem;display:none;animation:fadeInUp .4s ease-out}.alert-success{background:linear-gradient(135deg,rgba(34,197,94,.15),rgba(34,197,94,.05));border:1px solid rgba(34,197,94,.3);color:#22c55e}.alert-error{background:linear-gradient(135deg,rgba(220,38,38,.15),rgba(220,38,38,.05));border:1px solid rgba(220,38,38,.3);color:#dc2626}.alert.show{display:block}@media (max-width:768px){.admin-container{padding:1rem 15px}.admin-section{padding:1.5rem}.project-item{flex-direction:column}.project-item-actions{width:100%}.btn-delete,.btn-edit{flex:1 1}}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:1.5rem;gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:all .3s ease}.stat-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px rgba(0,0,0,.3);border-color:var(--accent-color)}.stat-icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.stat-info{flex:1 1}.stat-value{font-size:2rem;font-weight:700;color:var(--text-primary);line-height:1}.stat-label{font-size:.9rem;color:var(--text-secondary);margin-top:.25rem}.dashboard-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:1.5rem;gap:1.5rem;margin-bottom:2rem}.action-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:1.5rem;display:flex;align-items:center;gap:1rem;text-decoration:none;color:var(--text-primary);transition:all .3s ease;width:100%}button.action-card{cursor:pointer;font-family:inherit;font-size:inherit}.action-card:hover{transform:translateX(5px);border-color:var(--accent-color);background:rgba(107,70,193,.05)}.action-icon{width:50px;height:50px;background:rgba(107,70,193,.2);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:var(--accent-color);flex-shrink:0}.action-content{flex:1 1}.action-content h3{font-size:1.1rem;font-weight:600;margin:0 0 .25rem;color:var(--text-primary)}.action-content p{font-size:.85rem;color:var(--text-secondary);margin:0}.action-card>i{color:var(--text-secondary);font-size:1.2rem;transition:transform .3s ease}.action-card:hover>i{transform:translateX(5px);color:var(--accent-color)}.recent-projects{display:flex;flex-direction:column;gap:1rem}.recent-project-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1rem;display:flex;align-items:center;gap:1rem;transition:all .3s ease}.recent-project-item:hover{border-color:var(--accent-color);transform:translateX(5px)}.recent-project-thumbnail{width:80px;height:80px;border-radius:var(--border-radius);overflow:hidden;flex-shrink:0}.recent-project-thumbnail img{width:100%;height:100%;object-fit:cover}.recent-project-info{flex:1 1}.recent-project-info h4{font-size:1.1rem;font-weight:600;margin:0 0 .25rem;color:var(--text-primary)}.recent-project-info p{font-size:.85rem;color:var(--text-secondary);margin:0 0 .5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recent-project-meta{display:flex;gap:.75rem;font-size:.75rem}.project-category{background:rgba(107,70,193,.2);color:var(--accent-color);padding:.2rem .5rem;border-radius:4px;text-transform:capitalize}.project-date{color:var(--text-secondary)}.btn-view{padding:.5rem 1rem;background:transparent;border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-primary);text-decoration:none;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.btn-view:hover{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.breadcrumb{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-secondary);text-decoration:none;font-size:.9rem;margin-bottom:1rem;transition:color .3s ease}.breadcrumb:hover{color:var(--accent-color)}.projects-table{overflow-x:auto}.projects-table table{width:100%;border-collapse:collapse}.projects-table thead{background:rgba(107,70,193,.1)}.projects-table th{text-align:left;font-weight:600;border-bottom:2px solid var(--border-color)}.projects-table td,.projects-table th{padding:1rem;color:var(--text-primary)}.projects-table td{border-bottom:1px solid var(--border-color)}.projects-table tbody tr{transition:background .3s ease}.projects-table tbody tr:hover{background:rgba(107,70,193,.05)}.table-thumbnail{width:60px;height:60px;border-radius:8px;overflow:hidden}.table-thumbnail img{width:100%;height:100%;object-fit:cover}.table-title{font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.table-subtitle{font-size:.85rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:300px}.table-date{color:var(--text-secondary);font-size:.9rem}.table-actions{display:flex;gap:.5rem}.btn-icon{width:36px;height:36px;border-radius:6px;border:1px solid var(--border-color);background:transparent;color:var(--text-primary);cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;text-decoration:none}.btn-icon:hover{transform:translateY(-2px)}.btn-icon.btn-edit:hover{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.btn-icon.btn-delete:hover{background:#ef4444;border-color:#ef4444;color:#fff}.badge{padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500;text-transform:capitalize}.badge-graphisme{background:rgba(59,130,246,.2);color:#3b82f6}.badge-video{background:rgba(16,185,129,.2);color:#10b981}.btn{padding:.75rem 1.5rem;border-radius:8px;border:none;font-weight:500;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:.5rem;text-decoration:none}.btn-primary{background:var(--accent-color);color:#fff}.btn-primary:hover{background:#8b5cf6;transform:translateY(-2px);box-shadow:0 4px 12px rgba(107,70,193,.4)}.btn-danger{background:transparent;border:1px solid #ef4444;color:#ef4444}.btn-danger:hover{background:#ef4444;color:#fff;transform:translateY(-2px)}@media (max-width:768px){.projects-table{font-size:.9rem}.table-subtitle{max-width:150px}.projects-table td,.projects-table th{padding:.75rem .5rem}}.file-upload{margin-bottom:1.5rem}.file-upload-label{display:block;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.file-drop-zone{border:2px dashed var(--border-color);border-radius:var(--border-radius);padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .3s ease;background:rgba(107,70,193,.05)}.file-drop-zone:hover{border-color:var(--accent-color);background:rgba(107,70,193,.1)}.file-drop-zone p{margin:.5rem 0 .25rem;color:var(--text-primary);font-weight:500}.file-drop-zone span{color:var(--text-secondary);font-size:.85rem}.file-preview{border:1px solid var(--border-color);padding:1rem;background:var(--bg-primary)}.file-preview,.preview-container{border-radius:var(--border-radius)}.preview-container{margin-bottom:1rem;overflow:hidden;background:rgba(0,0,0,.1)}.preview-container img,.preview-container video{width:100%;max-height:300px;object-fit:contain;display:block}.preview-actions{display:flex;gap:.5rem}.btn-change,.btn-remove{flex:1 1;padding:.5rem 1rem;border-radius:6px;border:1px solid var(--border-color);background:transparent;color:var(--text-primary);cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-change:hover{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.btn-remove:hover{background:#ef4444;border-color:#ef4444;color:#fff}.btn-change:disabled,.btn-remove:disabled{opacity:.5;cursor:not-allowed}.file-upload-error{margin-top:.5rem;padding:.5rem;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:6px;color:#ef4444;font-size:.85rem;display:flex;align-items:center;gap:.5rem}.file-upload-hint{display:block;margin-top:.5rem;color:var(--text-secondary);font-size:.8rem}.image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#374151,#1f2937);color:#9ca3af;font-size:2rem}.table-thumbnail .image-placeholder{font-size:1.5rem}