*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;min-height:100vh;color:#1f2937;background-color:#fff}#root{min-height:100vh}.label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.5rem}.label-required{color:#ef4444;margin-left:.25rem}.input{width:100%;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:.5rem;font-size:1rem;font-family:inherit;transition:all .3s ease;background-color:#fff}.input:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.input:disabled{background-color:#f3f4f6;cursor:not-allowed}.input::placeholder{color:#9ca3af}.textarea{width:100%;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:.5rem;font-size:1rem;font-family:inherit;transition:all .3s ease;background-color:#fff;resize:vertical}.textarea:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.textarea:disabled{background-color:#f3f4f6;cursor:not-allowed}.textarea::placeholder{color:#9ca3af}.form-field{margin-bottom:1.5rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;font-family:inherit}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:#4f46e5;color:#fff}.btn-primary:hover:not(:disabled){background-color:#4338ca;transform:translateY(-2px);box-shadow:0 4px 6px #4f46e54d}.btn-secondary{background-color:#6b7280;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#4b5563;transform:translateY(-2px)}.btn-success{background-color:#10b981;color:#fff}.btn-success:hover:not(:disabled){background-color:#059669;transform:translateY(-2px)}.btn-danger{background-color:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background-color:#dc2626;transform:translateY(-2px)}.login-form-container{min-height:100vh;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.login-form-card{background:#fff;border-radius:1rem;padding:2rem;width:100%;max-width:450px;box-shadow:0 20px 25px -5px #0000004d}.login-form-header{text-align:center;margin-bottom:2rem}.login-form-header h1{font-size:2rem;color:#1f2937;margin-bottom:.5rem}.login-form-header p{color:#6b7280;font-size:.875rem}.login-form .btn{width:100%;margin-top:1rem}.login-error{padding:1rem;background-color:#fee2e2;border:1px solid #ef4444;border-radius:.5rem;color:#dc2626;margin-bottom:1rem;text-align:center;font-weight:500}.reset-data-button{margin-top:1.5rem;padding:.5rem 1rem;background:none;border:1px solid #e5e7eb;border-radius:.5rem;color:#6b7280;font-size:.75rem;cursor:pointer;width:100%;transition:all .3s ease;font-family:inherit}.reset-data-button:hover{background-color:#f9fafb;border-color:#d1d5db;color:#374151}.project-card{background:#fff;border-radius:1rem;overflow:hidden;box-shadow:0 4px 6px #0000001a;transition:all .3s ease;height:100%;display:flex;flex-direction:column}.project-card:hover{transform:translateY(-5px);box-shadow:0 10px 20px #00000026}.project-card-draft{border:2px solid #fbbf24;box-shadow:0 0 0 3px #fbbf2433}.project-card-image{width:100%;height:120px;overflow:hidden;position:relative}.project-card-image img{width:100%;height:100%;object-fit:cover}.draft-badge{position:absolute;top:.5rem;right:.5rem;background-color:#fbbf24;color:#78350f;padding:.25rem .75rem;border-radius:.5rem;font-size:.75rem;font-weight:600;box-shadow:0 2px 4px #0003}.project-card-content{padding:1rem;display:flex;flex-direction:column;flex-grow:1}.project-card-title{font-size:1.15rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.project-card-description{color:#6b7280;margin-bottom:.75rem;flex-grow:1;line-height:1.5;font-size:.9rem}.project-card-links{display:flex;gap:.4rem;margin-bottom:.75rem;flex-wrap:nowrap;justify-content:flex-start}.project-link{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background-color:#f3f4f6;border-radius:.4rem;text-decoration:none;color:#4b5563;font-size:.95rem;transition:all .3s ease;border:none;cursor:pointer;font-family:inherit}.project-link-github{background-color:#f3f4f6;color:#333}.project-link-vscode{background-color:#e0f2fe;color:#0369a1}.project-link-pdf{background-color:#fee2e2;color:#dc2626}.project-link-readme{background-color:#dbeafe;color:#1e40af}.project-link-documentation{background-color:#fef3c7;color:#d97706}.project-link-template{background-color:#e0e7ff;color:#6366f1}.project-link:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 4px 8px #00000026}.project-link-github:hover{background-color:#e5e7eb;color:#000}.project-link-vscode:hover{background-color:#bae6fd;color:#075985}.project-link-pdf:hover{background-color:#fecaca;color:#991b1b}.project-link-readme:hover{background-color:#bfdbfe;color:#1e3a8a}.project-link-documentation:hover{background-color:#fde68a;color:#b45309}.project-link-template:hover{background-color:#c7d2fe;color:#4f46e5}.project-card-actions{margin-top:auto;padding-top:.75rem;border-top:1px solid #e5e7eb}.project-card-arrows{display:flex;gap:.4rem;margin-bottom:.5rem}.project-card-arrows .btn{flex:1;padding:.4rem;font-size:1rem}.project-card-buttons{display:flex;gap:.5rem}.project-card-buttons .btn{flex:1;padding:.4rem .75rem;font-size:.9rem}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;padding:1.5rem 0}@media(max-width:768px){.project-grid{grid-template-columns:1fr;gap:1rem}}.modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:1rem;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000004d;padding:1rem}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.modal-header h2{margin:0;font-size:1.5rem;color:#1f2937}.modal-close{background:none;border:none;font-size:2rem;color:#6b7280;cursor:pointer;line-height:1;transition:color .3s ease}.modal-close:hover{color:#1f2937}.modal-form{padding:1.5rem}.file-input{width:100%;padding:.75rem 1rem;border:2px dashed #e5e7eb;border-radius:.5rem;font-size:1rem;font-family:inherit;transition:all .3s ease;cursor:pointer}.file-input:hover{border-color:#4f46e5}.image-preview{margin-top:1rem;border-radius:.5rem;overflow:hidden;border:2px solid #e5e7eb;position:relative;width:50%}.image-preview img{width:100%;height:120px;object-fit:cover;display:block}.remove-image-btn{position:absolute;top:.5rem;right:.5rem;background-color:#ef4444e6;color:#fff;border:none;padding:.5rem 1rem;border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #0003}.remove-image-btn:hover{background-color:#dc2626;transform:scale(1.05)}.remove-image-btn:disabled{opacity:.5;cursor:not-allowed}.file-name-display{margin-top:.75rem;padding:.75rem 1rem;background-color:#f3f4f6;border-radius:.5rem;color:#374151;font-size:.875rem;display:flex;align-items:center;gap:.5rem}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;padding:1rem;background-color:#fef3c7;border-radius:.5rem;border:2px solid #fbbf24;transition:all .3s ease}.checkbox-label:hover{background-color:#fde68a}.checkbox-input{width:1.25rem;height:1.25rem;cursor:pointer;accent-color:#f59e0b}.checkbox-label span{font-size:1rem;color:#92400e;font-weight:500}.modal-actions{display:flex;gap:1rem;margin-top:2rem}.modal-actions .btn{flex:1}.projects-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:2rem}.projects-header{max-width:1400px;margin:0 auto 2rem}.projects-header-content{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.projects-header h1{font-size:2.5rem;color:#1f2937;margin:0}.projects-header-info{display:flex;align-items:center;gap:1rem}.user-badge{padding:.5rem 1rem;background:#fff;border-radius:2rem;font-weight:600;color:#4f46e5;box-shadow:0 2px 4px #0000001a}.projects-header-actions{display:flex;justify-content:flex-end}.projects-container{max-width:1400px;margin:0 auto}.projects-empty{text-align:center;padding:4rem 2rem;background:#fff;border-radius:1rem;box-shadow:0 4px 6px #0000001a}.projects-empty h2{font-size:2rem;color:#6b7280;margin-bottom:.5rem}.projects-empty p{color:#9ca3af;margin-bottom:2rem}@media(max-width:768px){.projects-page{padding:1rem}.projects-header h1{font-size:1.75rem}.projects-header-content{flex-direction:column;align-items:flex-start}}.loading{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}
